我的程序里有这么一段代码:

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();
GetCustomerContactInfoModelFromPOGetShopContactInfoModelFromPO定义很简单,你懂的。
结果,在运行时,文章标题提到的异常出现了:
“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不识别方法***,因此该方法无法转换为存储表达式的更多相关文章

  1. mvc ef LINQ to Entities 不识别方法“Int32 Parse(System.String)”,因此该方法无法转换为存储表达式。

    private sys_User GetUserInfo() { sys_User model = null; var userId = Convert.ToInt32(AccountHelper.G ...

  2. LINQ to Entities 不识别方法“System.String ToString()”,因此该方法无法转换为存储表达式。

    var data = DataSource.Skip(iDisplayStart).Take(iDisplayLength).Select(o => new { MatNR = o.MatNR, ...

  3. Linq中字段数据类型转换问题(Linq to entity,LINQ to Entities 不识别方法"System.String ToString()"问题解决)

    1.在工作中碰到这样一个问题: 使用linq时,需要查询两个表,在这两张表中关联字段分别是int,和varchar()也就是string,在linq中对这两个字段进行关联, 如果强制类型转换两个不同类 ...

  4. Linq to Entities不识别方法

    db.UserValidates.Include(a => a.User).Where(uv => u.UserValidates.Contains(uv, c)).ToList(); 执 ...

  5. LINQ to Entities 不识别方法“System.DateTime AddDays(Double)

    今天本想在linq里按照时间筛选一下超时的数据,一共两个字段FeedBackTime(计划反馈时间).EndTime(实际反馈时间).需求是这样的,查找数据库里所有EndTime大于FeedBackT ...

  6. LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式。

    1.LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式.项目中发现linq to entities 不识别? , ...

  7. LINQ to Entities 不识别方法“System.Guid Parse(System.String)”,因此该方法无法转换为存储表达式。

    LINQ to Entities 不识别方法"System.Guid Parse(System.String)",因此该方法无法转换为存储表达式. linq 中不能转换类型

  8. LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式 的解决方法

    一.案例1,及解决方案: "LINQ to Entities 不识别方法"System.String ToString()",因此该方法无法转换为存储表达式." ...

  9. LINQ to Entities 不识别方法“System.String ToString(System.String)”,因此该方法无法转换为存储表达式。

    来源:https://www.cnblogs.com/hao-1234-1234/p/9112434.html 6  Select的时候,时间无法转换成 年月日  YYMMMdd 报错:LINQ to ...

随机推荐

  1. 区间型DP

    区间型DP是一类经典的动态规划问题,主要特征是可以先将大区间拆分成小区间求解最后由小区间的解得到大区间的解. 有三道例题 一.石子合并 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆. ...

  2. VMware克隆虚拟机,克隆机网卡启动不了解决方案

    Shutting down loopback interface: [ OK ] Bringing up loopback interface: [ OK ] Bringing up interfac ...

  3. C# JS 单例

    单例模式的三个特点: 1,该类只有一个实例 2,该类自行创建该实例(在该类内部创建自身的实例对象) 3,向整个系统公开这个实例接口 模式1: class Singleton { //私有,静态的类自身 ...

  4. Inno setup定制安装界面

    Innosetup功能很强大,可以通过它提供的Wizard接口来定制界面,但我对PASCAL语言不熟悉,也不清楚通过那种接口可改动的范围有多大,最后做出来的效果是否好,所以选择了通过一个DLL来实现我 ...

  5. Mac os x下配置nginx + php

    一直都没使用过PHP的,最近leader推荐使用他在维护的一个移动端的js框架,在本地合并压缩使用的是php环境处理的,so,只能是搭一个PHP的环境了.一直使用的本地代理服务器都是nginx,虽然P ...

  6. WCF android调用

    http://www.cnblogs.com/cg6811568/archive/2013/05/23/3095119.html

  7. php tools for visual studio 2013 完美 破解 Cracker

    PHP Tools for Visual Studio 2013,这个是 目前在 Visual Studio 2010/2012/2013 中 下最好用的php插件了,  破解 好的 Cracker  ...

  8. CAS 4.0.0RC 配置MD5验证功能

    配置内容同一样,只是增加一些配置. 因为cas已经默认就支持MD5加密验证,所以只是修改一下配置就可以了. <bean id="primaryAuthenticationHandler ...

  9. JavaScript 基础第四天

    一.前言 昨天我们了解了Js的很重要的一个概念叫做函数,函数就是对于冗余和垃圾代码的一种封装机制.简单的讲就是为了能让程序更好更快的执行我们将一些重复性的代码提取,封装成一个有名字的小盒子,等到我们需 ...

  10. Link To Sql简单

    Linq及其扩展 Linq是一种数据查询语言(它能够从多种数据源中查询数据). 现在基于Linq的扩展有: Linq To Object:主要是从内存对象中查询数据 Linq To Sql:主要是从M ...