Entity Framework Core: AsSplitQuery со сложными фильтрами не возвращает определенные свойства навигации при использованиC#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Entity Framework Core: AsSplitQuery со сложными фильтрами не возвращает определенные свойства навигации при использовани

Сообщение Anonymous »

У нас есть сложный запрос к сущности под названием Image. У этой сущности много свойств навигации, и мы используем AsSplitQuery, потому что здесь много изображений и много таблиц.
Запрос строится следующим образом:

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

var query = entity1Repository.Include(x => x.Entity2)
.ThenInclude(x => x.Entity3)
.Include(x => ...)
[...]
.AsSplitQuery();

if ([condition])
{
query = query.Where(x => ... );
}

if ([condition])
{
query = query.Where(x => ... );
}

// [more filters]

// Navigation property value for entity2 exist
var image = await query.SingleAsync(x => x.Id == 1234);

// Navigation property value for entity2 missing for some entity1
var result = await query.ToListAsync();
Когда запрос инициируется с помощью ToListAsync(), некоторые значения свойств навигации отсутствуют в некоторых объектах (не во всех).
При использовании .Single(x => x.Id == ...) свойства навигации загружаются корректно.
Без AsSplitQuery запрос работает нормально, если запрашивается мало данных, иначе время ожидания истекает, поэтому мы не можем удалите его.
Я использую EF Core 7.0.20, SQL Server и ASP.NET Core 6.
Конфигурация объекта работает нормально, здесь уже год не о чем сообщать.
Что может быть источником такого поведения?

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

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

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

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

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

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

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