实体框架核心:LINQ对实体的投影限制查询
使用实体框架核心时,直接在LINQ投影到实体查询中直接构造实体对象通常会导致错误:“实体或复杂类型不能在LINQ中构造到实体查询中。”
>。问题:
考虑此示例:
<code class="language-csharp">public IQueryable<Product> GetProducts(int categoryID) { return from p in db.Products where p.CategoryID == categoryID select new Product { Name = p.Name }; }</code>
用productRepository.GetProducts(1).ToList();
执行此操作将失败。
>为什么失败:
问题源于实体框架核心将LINQ查询转换为数据库命令的事实。数据库服务器缺乏对应用程序Product
类及其构造函数的了解。 因此,它不能创建此类的实例。
>解决方案:项目匿名类型或DTOS
>解决方案是将查询结果投影到匿名类型或专用数据传输对象(DTOS)中。
方法1:使用匿名类型
这是用于较小查询的快速而简单的解决方案:>
<code class="language-csharp">var products = (from p in db.Products where p.CategoryID == categoryID select new { Name = p.Name }).ToList();</code>
方法2:采用数据传输对象(DTOS)>
对于更复杂的方案或需要强大的对象时,请创建一个DTO:通过投影到匿名类型或DTO,您可以规避数据库实例化您的实体类,确保成功的查询执行。
以上是为什么在LINQ中构建实体对实体的预测会引发错误?的详细内容。更多信息请关注PHP中文网其他相关文章!