使用Visual Studio2015 运行Visual Studio2013的项目报错

 问题来源:之前使用Visual Studio2013 开发的B/S项目用Visual Studio2015运行报错

问题语句:

ll = db.model.Where(p => db.wx_shop_product.Where(o => (o.catalogId == request.catalogId)).Select(u => u.sku).Contains(p.CouponNo)).Select(y => y.Cid).ToList();

 

代码修改为:

 

           var aa = db.wx_shop_product.Where(o => (o.catalogId == request.catalogId)).Select(u => u.sku);
                     ll = db.model.Where(p => aa.Contains(p.CouponNo)).Select(y => y.Cid).ToList();

 

在Visual Studio2015不报错,但是这种修改的地方很多不可预计,而且发现使用较复杂的LINQ语句时候也会报错。

 

尝试解决这个问题:

解决办法1:升级EntityFramework的版本,将4.4 换成6.0。

结果:报相同错误

 

解决办法2:比对前后dll文件, 

结果:引用的dll文件一致,一样的代码在2015生成的dll文件报错

解决办法3:重新安装vs2013

结果:成功运行代码

找到一部分原因

在vs2015 里面写let会多一条全表联查语句 ,比如

/let khoo = dbContext.dt_orders.Where(o=>o.ID==1).FirstOrDefault()

数据库会多出一条

select * from dt_orders

最终mei'没解决 放弃 ,使用vs2013

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值