Создайте API-интерфейс get, который возвращает ядро ​​BLOB .net (EF).C#

Место общения программистов C#
Ответить
Anonymous
 Создайте API-интерфейс get, который возвращает ядро ​​BLOB .net (EF).

Сообщение Anonymous »

У меня есть база данных с таблицей, которая имеет идентификатор и BLOB.
Я хочу получить большой двоичный объект и, по сути, передать его клиенту,
а не извлекать его в память. Это связано с тем, что большой двоичный объект может быть очень большим (сотни МБ).

Я почти добился этого с помощью SQLdataReader.
При этом, когда я делаю запрос на получение, загрузка начинается немедленно, и нагрузка на память не увеличивается. Это использовало .net core 2.2
Однако, когда я перешел на .net core 3.1, теперь он не работает, и память заполняется сотнями мегабайт. Я также хотел бы добиться того же результата, используя структуру сущности, но до сих пор я не нашел хороших онлайн-ресурсов.

Вот код, который у меня есть на данный момент.

Код: Выделить всё

[HttpGet]
public  IEnumerable GetStreaming()
{

var header = Request.Headers["Accept-Encoding"];
System.Console.WriteLine(header);

string connectionString = "Data Source=myPc\\SQLEXPRESS;Initial Catalog=dbo;Persist Security Info=True;User ID=sa;Password=admin";

//----------------------
SqlConnection connection = new SqlConnection(connectionString);

connection.Open();

SqlCommand command = new SqlCommand("exec getBlob", connection);

SqlTransaction tran = connection.BeginTransaction(IsolationLevel.ReadCommitted);
command.Transaction = tran;
byte[] buffer = new byte[5000000];
long position = 0;
long bytesRead = 5000000;
using (SqlDataReader reader = command.ExecuteReader(CommandBehavior.SequentialAccess))
{
reader.Read();
reader.GetBytes(0, position, null, 0, 5000000);
while (bytesRead == 5000000)
{
// Get the pointer for file
bytesRead = reader.GetBytes(0, position, buffer, 0, 5000000);
position += bytesRead;
yield return buffer;

// Create the SqlFileStream

}

}

}
Я пробовал сделать это вот так

Код: Выделить всё

        public  IEnumerable DownloadFile()
{

yield return  context.t_noFs.Where(u => u.Id == 1)
.Select(u => u.dat).
FirstOrDefault();
}
и хотя это возвращает значение, оно не дает желаемого эффекта и заполняет память.

Подробнее здесь: https://stackoverflow.com/questions/599 ... et-core-ef
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»