首页 >后端开发 >C++ >为什么在LINQ中构建实体对实体的预测会引发错误?

为什么在LINQ中构建实体对实体的预测会引发错误?

Linda Hamilton
Linda Hamilton原创
2025-02-01 15:06:11627浏览

Why Does Constructing Entities in LINQ to Entities Projections Throw an Error?

实体框架核心: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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn