EF Core, почему возвращаются связанные свойстваC#

Место общения программистов C#
Ответить
Anonymous
 EF Core, почему возвращаются связанные свойства

Сообщение Anonymous »

В проекте мы используем Entity Framework Core 2.1.14. Когда я попробовал два оператора, показанных ниже, сгенерированный SQL был разным, но оба вернули связанные свойства.
A HouseholdMmbrPrfl имеет отношение 1:M к HouseholdMemberIncomes:
var test1 = await _dbContext.HouseholdMmbrPrfl
.Where(x => x.HouseholdMemberProfileId == memberId)
.FirstOrDefaultAsync();

var test2 = await _dbContext.HouseholdMmbrPrfl
.Include(x => x.HouseholdMemberIncomes)
.Where(x => x.HouseholdMemberProfileId == memberId)
.FirstOrDefaultAsync();

Я думал, что .Include понадобится для получения HouseholdMemberIncomes, но всякий раз, когда я смотрю на test1, я вижу HouseholdMemberIncomes, заполненный в объекте , развернул объект. Я вижу детали, но не вижу другого SQL-запроса в консоли отладки.
У меня запрос выводится как:
.UseLoggerFactory(LoggerFactory.Create(builder => builder.AddDebug())

Я думал, что test1 не будет содержать HouseholdMemberIncomes. Запрос для test1 запрашивал только таблицу HouseholdMmbrPrfl, запрос был test2 Я видел, как было выполнено 2 запроса один раз к HouseholdMmbrPrfl и второй к HouseholdMemberIncomes
Когда вам понадобится .Include, если в любом случае данные были там, я предположил, что это была ленивая загрузка свойств, но я не смог найти ее включенной (нет UseLazyLoadingProxies), и свойство не является виртуальным.
public List HouseholdMemberIncomes { get; set; }


Подробнее здесь: https://stackoverflow.com/questions/793 ... g-returned
Ответить

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

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

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

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

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