Неявный AsQueryableC#

Место общения программистов C#
Ответить
Anonymous
 Неявный AsQueryable

Сообщение Anonymous »

Следующий код linq2entities может вызывать IEnumerable версию расширения FirstOrDefault, поскольку PersonHistories — это ICollection. Однако во время выполнения он фактически вызывает версию IQueryable.

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

var test = db.Persons.Where(d => d.PersonKey == 4)
.Select(f => f.PersonHistories.FirstOrDefault());
Проблема заключается в том, что используемый мной пользовательский поставщик запросов не выполняет это автоматическое преобразование, и я получаю сообщение об ошибке «...ICollection нельзя использовать для параметра типа IQueryable». Таким образом, чтобы обойти эту проблему, требуется явный вызов AsQueryable, но для сложных запросов это становится очень избыточным и не кажется очень СУХИМ:

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

db.Persons.Where(d => d.PersonKey == 4)
.Select(f => f.PersonHistories.AsQueryable().FirstOrDefault());
Я покопался в справочном источнике платформы, пытаясь найти информацию о посетителях/поставщиках Linq 2 Entities, но безуспешно (возможно, это не часть ни одного из открытых справочных источников). Как базовые поставщики реализуют такое неявное использование AsQueryable?

Я понимаю, что они преобразуются в деревья выражений.
Я понимаю, что Enumerable.FirstOrDefault заменяется поставщиком на Queryable.FirstOrDefault. В этом суть вопроса.

Подробнее здесь: https://stackoverflow.com/questions/110 ... squeryable
Ответить

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

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

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

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

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