если вы выполняете Linq to Entity
, вы не можете использовать ClassType
с new
в select
закрытии запроса only anonymous types are allowed (new without type)
взгляните на этот фрагмент моего проекта
//...
var dbQuery = context.Set<Letter>()
.Include(letter => letter.LetterStatus)
.Select(l => new {Title =l.Title,ID = l.ID, LastModificationDate = l.LastModificationDate, DateCreated = l.DateCreated,LetterStatus = new {ID = l.LetterStatusID.Value,NameInArabic = l.LetterStatus.NameInArabic,NameInEnglish = l.LetterStatus.NameInEnglish} })
^^ without type__________________________________________________________________________________________________________^^ without type
из вас добавили new keyword
в закрытии Select даже на complex properties
, вы получите эту ошибку
, поэтому remove
ключевое слово ClassTypes from new
на Linq to Entity
запросы ,,
, поскольку он будет преобразован в оператор sql и выполнен на SqlServer
, поэтому когда я смогу использовать new with types
на select
closure?
вы можете использовать его, если вы имеете дело с LINQ to Object (in memory collection)
//opecations in tempList , LINQ to Entities; so we can not use class types in select only anonymous types are allowed
var tempList = dbQuery.Skip(10).Take(10).ToList();// this is list of <anonymous type> so we have to convert it so list of <letter>
//opecations in list , LINQ to Object; so we can use class types in select
list = tempList.Select(l => new Letter{ Title = l.Title, ID = l.ID, LastModificationDate = l.LastModificationDate, DateCreated = l.DateCreated, LetterStatus = new LetterStatus{ ID = l.LetterStatus.ID, NameInArabic = l.LetterStatus.NameInArabic, NameInEnglish = l.LetterStatus.NameInEnglish } }).ToList();
^^^^^^ with type
после того, как я выполнил ToList
по запросу, он стал in memory collection
, поэтому мы можем использовать new ClassTypes
в select