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 = oei.CreatedUserId,
ExpressId = oei.ExpressId,
ExpressName = oei.ExpressName,
ExpressOrderId = oei.ExpressOrderId,
Freight = oei.Freight,
Manifest = oei.Manifest,
OrderId = oei.OrderId,
ReceiverContactInfo = new ContactInfoModel()
{
ZipCode = oei.CustomerZipCode,
Telephone = oei.CustomerPhone,
MobilePhone = oei.CustomerTel,
Address = oei.CustomerAddress,
LinkMan = oei.CustomerReceiverName,
ProvinceId = oei.CustomerArea.ProvinceId,
ProvinceName = oei.CustomerArea.ProvinceName,
CityId = oei.CustomerArea.CityId,
CityName = oei.CustomerArea.CityName,
CountyId = oei.CustomerArea.DistrictId,
CountyName = oei.CustomerArea.DistrictName
},
ShopId = order.OrderId,
ShopName = order.ShopName,
ShopContactInfo = new ContactInfoModel()
{
ZipCode = oei.ShopZipCode,
Telephone = oei.ShopTel,
MobilePhone = oei.ShopPhone,
Address = oei.ShopAddress,
LinkMan = oei.ShopLinkMan,
ProvinceId = oei.ShopArea.ProvinceId,
ProvinceName = oei.ShopArea.ProvinceName,
CityId = oei.ShopArea.CityId,
CityName = oei.ShopArea.CityName,
CountyId = oei.ShopArea.DistrictId,
CountyName = oei.ShopArea.DistrictName
}
}).FirstOrDefault();
其中,ContactInfoModel是一个实体类,定义了买家或卖家的contact信息, 实体类 EbcBuy.Bll.Orders.Models.OrderExpress
具备两个该类型的属性, ReceiverContactInfo和ShopContactInfo。 这里使用linq to entity要给这2个属性赋值, 要注意了,这里给ContactInfoModel初始化设置的属性个数和顺序必须相同。 否则,运行时会报如下异常:
“System.NotSupportedException”类型的未经处理的异常在 EntityFramework.dll 中发生
其他信息: 在单个 LINQ to Entities 查询中的两个结构上不兼容的初始化过程中出现类型“EbcBuy.Bll.Common.Models.ContactInfoModel”。类型可以在同一查询中的两个位置初始化,但前提是在这两个位置设置了相同的属性,且这些属性是以相同的顺序设置的。
我这个ContactInfoModel在项目里好多的linq to entity代码里进行这样的初始化, 为了提高复用,我把上面的初始化封装成了一个方法, 供各处调用。 修改后的代码如下:
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 = oei.CreatedUserId,
ExpressId = oei.ExpressId,
ExpressName = oei.ExpressName,
ExpressOrderId = oei.ExpressOrderId,
Freight = oei.Freight,
Manifest = oei.Manifest,
OrderId = oei.OrderId,
ReceiverContactInfo = GetCustomerContactInfoModelFromPO(oei),
ShopId = order.OrderId,
ShopName = order.ShopName,
ShopContactInfo = GetShopContactInfoModelFromPO(oei)
}).FirstOrDefault();
GetCustomerContactInfoModelFromPO和GetShopContactInfoModelFromPO定义很简单,你懂的。
结果,在运行时,文章标题提到的异常出现了:
“System.NotSupportedException”类型的未经处理的异常在 EntityFramework.dll 中发生
其他信息: LINQ to Entities 不识别方法“EbcBuy.Bll.Common.Models.ContactInfoModel GetCustomerContactInfoModelFromPO(EbcBuy.Dal.Orders.Models.OrderInfo)”,因此该方法无法转换为存储表达式。
【园子里搜索了一下, 有如下结论】在LINQ to Entities 中,使用lambda或linq时,变量一定要提前转换好,可不能到lambda里或linq里再转换。如:
var o= _db.Dictionary.Where(x => x.Type.Equals(type4.ToString()));
.ToString必然产生错误,应该:
string t=type4.ToString();
var o= _db.Dictionary.Where(x => x.Type.Equals(t));
用lambda或linq时,不要尝试去转换内置类型,是不允许的,如:
string t=type4.ToString();
var o= _db.Dictionary.Where(x => Convert.ToString(x.Type).Equals(t));
Convert.ToString必然要出错.
可以考虑使用如下方式:
using System.Data.Objects.SqlClient; //在 System.Data.Entity.dll 中
//获取市级地区
public JsonResult GetCity(string id)
{
var city = from c in db.AreaDivide
where SqlFunctions.StringConvert((double)c.ParentID) == id
select new { text = c.AreaName, value = c.ID }; return Json(city.ToList(), JsonRequestBehavior.AllowGet);
}
不过,像我这种情况,无法复用的话,还真是谈不上简洁性了。不晓得还有没有什么好的解决办法...
LINQ to Entities不识别方法***,因此该方法无法转换为存储表达式的更多相关文章
- mvc ef LINQ to Entities 不识别方法“Int32 Parse(System.String)”,因此该方法无法转换为存储表达式。
private sys_User GetUserInfo() { sys_User model = null; var userId = Convert.ToInt32(AccountHelper.G ...
- LINQ to Entities 不识别方法“System.String ToString()”,因此该方法无法转换为存储表达式。
var data = DataSource.Skip(iDisplayStart).Take(iDisplayLength).Select(o => new { MatNR = o.MatNR, ...
- Linq中字段数据类型转换问题(Linq to entity,LINQ to Entities 不识别方法"System.String ToString()"问题解决)
1.在工作中碰到这样一个问题: 使用linq时,需要查询两个表,在这两张表中关联字段分别是int,和varchar()也就是string,在linq中对这两个字段进行关联, 如果强制类型转换两个不同类 ...
- Linq to Entities不识别方法
db.UserValidates.Include(a => a.User).Where(uv => u.UserValidates.Contains(uv, c)).ToList(); 执 ...
- LINQ to Entities 不识别方法“System.DateTime AddDays(Double)
今天本想在linq里按照时间筛选一下超时的数据,一共两个字段FeedBackTime(计划反馈时间).EndTime(实际反馈时间).需求是这样的,查找数据库里所有EndTime大于FeedBackT ...
- LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式。
1.LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式.项目中发现linq to entities 不识别? , ...
- LINQ to Entities 不识别方法“System.Guid Parse(System.String)”,因此该方法无法转换为存储表达式。
LINQ to Entities 不识别方法"System.Guid Parse(System.String)",因此该方法无法转换为存储表达式. linq 中不能转换类型
- LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式 的解决方法
一.案例1,及解决方案: "LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式." ...
- LINQ to Entities 不识别方法“System.String ToString(System.String)”,因此该方法无法转换为存储表达式。
来源:https://www.cnblogs.com/hao-1234-1234/p/9112434.html 6 Select的时候,时间无法转换成 年月日 YYMMMdd 报错:LINQ to ...
随机推荐
- 京东2017校园招聘笔试题 【第K个幸运数】
题目描述 4和7是两个幸运数字,我们定义,十进制表示中,每一位只有4和7两个数的正整数都是幸运数字. 前几个幸运数字为:4,7,44,47,74,77,444,447... 现在输入一个数字K,输出第 ...
- Oracle 11g 服务器安装图解
平常Oracle都是安装到本地的,没有安装到服务器过,今天找了个帖子是安装到服务器的图解 http://jingyan.baidu.com/album/948f5924373c04d80ff5f9f5 ...
- 【转】当你在浏览器地址栏输入一个URL后回车,将会发生的事情?
http://igoro.com/archive/what-really-happens-when-you-navigate-to-a-url/ http://www.cnblogs.com/panx ...
- centOS升级python3.5
CentOS自带的版本是2.7.5 目前在看廖老师的教学,他给的新版本是3以上了,果断升级到最新的Python版本 (windows下面多线程里面有点问题没解决,所以才换到linux下继续学习) 一 ...
- (转)Java中的static关键字解析
转自http://www.cnblogs.com/dolphin0520/p/3799052.html 一.static关键字的用途 在<Java编程思想>P86页有这样一段话: “sta ...
- Win7 64位 MinGW环境测试SDL2.0.3
下载MinGW版的文件 http://www.libsdl.org/release/SDL2-devel-2.0.3-mingw.tar.gz 解压放到mysys下面 运行Makefile mysys ...
- Merge在Sqlserver使用例子说明
---文章 MatchInt的方式 Create table SourceTable([ID] int,[Desc] varchar(50)); Create table TargetTable([I ...
- H3C IRF mad检测
这里 irf 两个交换机 S4 S5 S4 S4的MEmber id 为1 IRF member 1 renumber 1 S4的 irf 优先为10 irf member priority 10 链 ...
- CSS盒模型
CSS盒模型是CSS 可视化格式化系统的基石,它是理解样式表如何工作的核心概念.盒模型用于元素定位和页面布局.元素框的最内部分是实际的内容,直接包围内容的是内边距.内边距呈现了元素的背景.内边距的边缘 ...
- [Leetcode][JAVA] Path Sum I && II
Path Sum Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that addi ...