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

初学asp.net 代码出现LINQ to Entities 查询中无法构造实体或复杂类型提示,看了论坛里已有的类似问题,好像是说类型太多,但我这里非常简单,不知道为什么也出这个问题,求解!谢谢!


public IList<School> All()
{
    var query = from c in OD.Schools
             select new School
             {
                 ID = c.ID,
                 FName = c.FName,
                 SName = c.SName
             };

    return query.ToList();
}
ToList直接跟在linq里也出同样的错.同cs下的其他不select nwe school的就没事.如下



public IList<School> GetSchoolByBelongTo(int belongTo)
{
    var query = from c in OD.Schools 
                where c.BelongTo == belongTo
                select c;


    return query.ToList();
}
---------------------------------------------------------------------------------------------------


解决办法:

重新定义一个Model类,名字叫MSchool
不要使用映射的实体作为返回值类型


public class MSchool
{	
	//字段
	string ID {get;set;}
	string FName {get;set;}
	string SName {get;set;}
}


public IList<MSchool> All()
{
	var query = from c in OD.Schools
	select new MSchool
	{
		  ID = c.ID,
		  FName = c.FName,
		  SName = c.SName
	};
	return query.ToList();
}


转载于:https://my.oschina.net/Yamazaki/blog/115770

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值