在 LINQ to Entities 查询中无法构造实体或复杂类型

在编写EF+Linq的过程中,可能会遇到“在 LINQ to Entities 查询中无法构造实体或复杂类型”的问题。
解决方法:从原有类型中继承一个子类,然后创建子类实例
下面是例子:

private static void Main(string[] args)
        {
            Boolean s = false;
            using(Northwind dbo = new Northwind())
            {
                IQueryable<Customers> query;
                if(s)
                {
                    // 错误的写法,会出现 “在 LINQ to Entities 查询中无法构造实体或复杂类型”错误
                    query = from a in dbo.Customers
                            select new Customers()
                            {
                                                            ID=a.ID,
                                Address = a.Address
                            };
                }
                else
                {
                    // 解决方法,从原有类型中继承一个子类
                    query = from a in dbo.Customers
                            select new CustomerChild()
                            {
                                                            ID=a.ID,
                                Address = a.Address
                            };
                }
                var c = query.ToList();
                Console.WriteLine(c.Count);
                Console.Read();
            }
        }
        private class CustomerChild : Customers { }

原文地址:https://blog.51cto.com/twoxzi/2443954

时间: 2025-01-13 23:11:31

在 LINQ to Entities 查询中无法构造实体或复杂类型的相关文章

在 LINQ to Entities 查询中无法构造实体或复杂类型“Cits.Data.LineImg”。

错误代码: adlist = _sImg.Where(o => o.AdType == 11).OrderBy(o => o.Desc).OrderByDescending(o => o.Id).Select(i => new LineImg { Url = i.Url, ImgUrl = i.ImgUrl, Title = i.Title }).ToList(); 修正代码: adlist = _sImg.Where(o => o.AdType == 11).OrderBy

Linq to Entities中无法构造实体或复杂类型

EF中在使用linq就行查询select时不能直接使用自动映射生成的类,需要在单独声明一个类或者使用匿名类在查询完成后再转为对应的对象. 1 public partial class WebForm1 : System.Web.UI.Page 2 { 3 protected void Page_Load(object sender, EventArgs e) 4 { 5 using (aspnetdbEntities db = new aspnetdbEntities()) 6 { 7 //My

单个 LINQ to Entities 查询中的两个结构上不兼容的初始化过程中出现类型“XXXX”

最近在做一个报表的时候,用EF使用了Contact方法,但是程式运行一直出错.最近终于找到原因了,写下来提醒下自己.好了,进入正题: 现在我举个栗子,目前数据库中有ParentStudent表和SubStudent表,现在需要将两张表联合起来后再使用分页查询. 表ParentStudent和SubStudent的结构完全一样,我这边就只展示SubParent表的结构了: CREATE TABLE [dbo].[SubStudent]( [ID] [varchar](10) NOT NULL, [

LINQ to Entities 查询注意事项

1> 排序信息丢失 如果在排序操作之后执行了任何其他操作,则不能保证这些附加操作中会保留排序结果.这些操作包括 Select 和 Where 等.另外,采用表达式作为输入参数的 First 和 FirstOrDefault 方法不保留顺序.如下代码:并不能达到反序排序的效果 using (var edm = new NorthwindEntities()) { IQueryable<Customers> cc = edm.Customers.OrderByDescending(c =&g

LINQ to Entities 查询语法

转自: http://www.cnblogs.com/asingna/archive/2013/01/28/2879595.html 实体框架(Entity Framework )是 ADO.NET 中的一套支持开发面向数据的软件应用程序的技术. LINQ to Entities 提供语言集成查询 (LINQ) 支持,它允许开发人员使用 Visual Basic 或 Visual C# 根据实体框架概念模型编写查询.针对实体框架的查询由针对对象上下文执行的命令目录树查询表示.LINQ to En

LINQ to Entities不识别方法***,因此该方法无法转换为存储表达式

我的程序里有这么一段代码: order.OrderExpressInfo = (from oei in orderExpressRepository.Entities where oei.OrderId == order.OrderId select new EbcBuy.Bll.Orders.Models.OrderExpress { ContentInfo = oei.ContentInfo, CreatedTime = oei.CreatedTime, CreatedUserId = oe

linq和lamda表达式中添加时间判断时解决方案

在工作中遇到个问题,在使用lamda查询数据的时候,需要添加一个时间判断, DateTime.AddDays(3) > e.ExpirationDate 例如:list = Context.VoucherUserSignPLView.Where(e => e.IsUse == isUse && e.ExpirationDate >= DateTime.Now && DateTime.AddDays(days) > e.ExpirationDate).

Entity Framework技术系列之7:LINQ to Entities

小分享:我有几张阿里云优惠券,用券购买或者升级阿里云相应产品最多可以优惠五折!领券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 前言 LINQ(Language Integrated Query,语言集成查询)是一组用于C#和VB.NET语言的扩展,它允许编写C#或者VB.NET代码,以与查询数据库相同的方式操作内存数据.LINQ提Entity Framework技术系

LINQ(LINQ to Entities)

LINQ to Entities 是 LINQ 中最吸引人的部分.它让你可以使用标准的 C# 对象与数据库的结构和数据打交道.使用 LINQ to Entities 时,LINQ 查询在后台转换为 SQL 查询并在需要数据的时候执行,即开始枚举结果的时候执行.LINQ to Entities 还为你获取的所有数据提供变化追踪,也就是说,可以修改查询获得的对象,然后整批同时把更新提交到数据库. LINQ to Entities 是 Entity Framework 的一部分并且取代 LINQ to