问题解决连接:https://*.com/questions/5325797/the-entity-cannot-be-constructed-in-a-linq-to-entities-query
链接是外文,我来翻译一下,意思是相通的,主要是记录一下供以后自己参考
问题描述: product这个类是EF跟数据库实体关联的类,然后写了如下一个查询方法
public IQueryable<Product> GetProducts(int categoryID)
{
return from p in db.Products
where p.CategoryID== categoryID
select new Product { Name = p.Name};
}
当需要用到这个方法查询结果的时候,就像这样:
var products = productRepository.GetProducts().Tolist();
就会抛出异常:
"The entity or complex type Shop.Product cannot be constructed in a LINQ to Entities query"
但是如果把方法改成下面这样就没有问题:
public IQueryable<Product> GetProducts(int categoryID)
{
return from p in db.Products
where p.CategoryID== categoryID
select p;
}
这是为什么呢?可是我需要连接两张表,并且需要两张表的信息呢?
答案是,你用一个简单的类,什么是简单类呢?就是非“EF跟数据库实体关联的类”,就可以啦,然后把你想要的数据赋值进去就ok。
比如这样,新建一个类叫SimpleProduct:
public class SimpleProduct {
public string Name { get; set; }
}
然后把方法改成:
public IQueryable<Product> GetProducts(int categoryID)
{
return from p in db.Products
where p.CategoryID== categoryID
select new SimpleProduct { Name = p.Name};
}