Как я могу безопасно закрыть SqlDataReader при получении BLOB-данных SQL через поток? [дубликат]C#

Место общения программистов C#
Ответить
Anonymous
 Как я могу безопасно закрыть SqlDataReader при получении BLOB-данных SQL через поток? [дубликат]

Сообщение Anonymous »

У меня есть следующая функция, которая работает как функция конечной точки в моем веб-API .NET. Эта функция считывает BLOB (как varbinary(MAX)) из базы данных SQL (видео, изображение, аудио) и возвращает как поток.

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

[HttpGet("GetMediaVal/{id}")]
public async Task GetMediaValue(Guid id)
{
SqlConnection con = new SqlConnection(_connectionString);

try
{
await con.OpenAsync();

using (SqlCommand cmd = con.CreateCommand())
{
cmd.CommandText = "SELECT TOP 1 med_ext, med_val FROM media WHERE id = @id";
cmd.Parameters.AddWithValue("id", id);

SqlDataReader reader = await cmd.ExecuteReaderAsync(CommandBehavior.SequentialAccess | CommandBehavior.SingleRow | CommandBehavior.CloseConnection);

if (!await reader.ReadAsync())
return NotFound();

string med_ext = reader.GetString(0);
if (String.IsNullOrWhiteSpace(med_ext) || !new FileExtensionContentTypeProvider().TryGetContentType(Path.ChangeExtension("file", med_ext), out string contentType))
contentType = "application/octet-stream"; // Fallback

if (reader.IsDBNull(1))
return NotFound();

Stream s = reader.GetStream(1);
return File(s, contentType, true);
}
}
catch (Exception ex)
{
await con.CloseAsync();
return StatusCode((int)HttpStatusCode.InternalServerError, "Error");
}
}
Как безопасно закрыть SqlDataReader после завершения потоковой передачи? Я не могу использовать оператор using, поскольку он уничтожит Reader до полной передачи потока. SqlConnection закрывается из-за параметра CommandBehavior.CloseConnection, поэтому все работает нормально. Есть ли аналогичный способ использования с читалкой?

Подробнее здесь: https://stackoverflow.com/questions/798 ... -via-strea
Ответить

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

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

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

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

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