J'ai vu ce code de travail avec LINQ to SQL, mais lorsque j'utilise Entity Framework, il met cette erreur:
LINQ to entities ne reconnaît pas la méthode " du Système.Linq.IQueryable'1[MyProject.Modèles.CommunityFeatures] GetCommunityFeatures ()', et cette méthode ne peut pas être traduit dans un magasin d'expression".
Le référentiel de code est ceci:
public IQueryable<Models.Estate> GetEstates()
{
return from e in entity.Estates
let AllCommFeat = GetCommunityFeatures()
let AllHomeFeat = GetHomeFeatures()
select new Models.Estate
{
EstateId = e.EstateId,
AllHomeFeatures = new LazyList<HomeFeatures>(AllHomeFeat),
AllCommunityFeatures = new LazyList<CommunityFeatures>(AllCommFeat)
};
}
public IQueryable<Models.CommunityFeatures> GetCommunityFeatures()
{
return from f in entity.CommunityFeatures
select new CommunityFeatures
{
Name = f.CommunityFeature1,
CommunityFeatureId = f.CommunityFeatureId
};
}
public IQueryable<Models.HomeFeatures> GetHomeFeatures()
{
return from f in entity.HomeFeatures
select new HomeFeatures()
{
Name = f.HomeFeature1,
HomeFeatureId = f.HomeFeatureId
};
}
LazyList est une Liste qui s'étend le pouvoir de IQueryable.
Quelqu'un pourrait-il expliquer pourquoi cette erreur se produit?