Запрос больших наборов данных с помощью EFCore 8 занимает больше времени, тогда как хранимая процедура или оператор SELEC#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Запрос больших наборов данных с помощью EFCore 8 занимает больше времени, тогда как хранимая процедура или оператор SELE

Сообщение Anonymous »

Я переношу приложение WCF в веб-базу Balzor с помощью EFCore 8.
В WCF получение данных (200 тыс. записей) из представления занимает 10–12 секунд.
Моя общая таблица содержит ок. 45 миллионов записей. Из них 200 000 отфильтрованных записей.
Пока я пытаюсь использовать EFCore, это занимает 3 минуты. Его нужно получить за меньшее время.
Мой метод заключается в следующем.

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

public async Task ReportDatAsync(DatbaseContext dbContext. DataDto params, CancellationToken ct)
{
IDictionary searchParams = new Dictionary
{
{ "Year", string.Join(",",params.Year) },
{ "Month", string.Join(",", params.Period) },
{ "Type", string.Join(",",  params.Type) }
};
var queryBuilder = new StringBuilder(@"SELECT * FROM table WHERE 1=1");

foreach (var filter in searchParams)
{
if (filter.Value != null && filter.Value.Any())
{
var formattedValues = string.Join(",", filter.Value.Split(',').Select(v => $"'{v.Trim()}'"));
queryBuilder.Append($" AND {filter.Key} IN ({formattedValues})");
}
}
var queryString = queryBuilder.ToString();
var queryText = dbContext.table.FromSqlRaw(queryString).AsNoTracking();
var data1 = await queryText.ToListAsync(ct);
}

Я не хочу привязывать набор результатов к какой-либо модели. У меня та же логика в WCF с Stystem.Data.Entity, и она извлекает данные за 10-12 секунд.
Мое приложение не поддерживает многопоточность для одновременного выполнения нескольких запросов.< /p>
Заранее благодарим вас за ваш вклад.

Подробнее здесь: https://stackoverflow.com/questions/792 ... red-proced
Реклама
Ответить Пред. темаСлед. тема

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Хранимая процедура не работает в Snowflake
    Anonymous » » в форуме Python
    0 Ответы
    32 Просмотры
    Последнее сообщение Anonymous
  • Сложная хранимая процедура MySQL возвращает NULL в PHP
    Anonymous » » в форуме Php
    0 Ответы
    35 Просмотры
    Последнее сообщение Anonymous
  • Хранимая процедура сервера MSSQL не возвращает выходные параметры при вызове из С++
    Anonymous » » в форуме C++
    0 Ответы
    30 Просмотры
    Последнее сообщение Anonymous
  • Не знаю, почему моя хранимая процедура не работает между pyodbc и SQL Server.
    Anonymous » » в форуме Python
    0 Ответы
    30 Просмотры
    Последнее сообщение Anonymous
  • Хранимая процедура не запускается через 10 минут
    Anonymous » » в форуме C#
    0 Ответы
    17 Просмотры
    Последнее сообщение Anonymous

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