LINQ to Entities 不识别方法

2 篇文章 0 订阅
 
有时候我们在Select(投影)一些列的时候可能很自然需要使用一些方法,比如下面的代码。

[c-sharp:nogutter] view plain copy print ?
  1. var ug = from g in _entities.UserGroupSet  
  2.           where g.Users.uid == 1  
  3.           select g.Groups.gid.ToString();  

源数据gid是整形的,我们现在需要的结果是转换成string的一个集合,所以在select语句后面使用了ToString(),这在Linq to SQL或者Linq to Object都是没有问题的。但是在Linq to Entities的时候会在运行时报错:LINQ to Entities 不识别方法“System.String ToString()”,无法将表达式转换云云。

 

 

此举据说是为了支持更多种类的数据库。不管出于什么原因不支持,几个地方表现不一致确实让人挺纠结的。不过问题还是得解决。怎么做比较简单呢?请看下面的代码:

[c-sharp] view plain copy print ?
  1. var ug = (from g in _entities.UserGroupSet  
  2.           where g.Users.uid == 1  
  3.           select g.Groups.gid).ToList().Select(c=>c.ToString());  

 

在这句代码中,使用了Select这个扩展方法,把最后的结果一下子转换成了string,简洁方便。

 

需要注意的地方是中间有个ToList()。如果你不加ToList()直接接上Select扩展方法,同样会报上面的错误。

这是由Linq to Entities的延迟加载机制造成的。在真正加载数据前的所有语句,都将被转换成sql语句,而“Linq to Entities不识别方法。。。”,所以我们需要先ToList(),这将让前面的语句全部转换并且加载数据,而后面的Select是针对这个List<int>来做的,所以,没有问题。

 

 

下面举一个例子。当我们要在Linq中做到sql语句where xx in (1,2,3)这样的效果时,我们会想到用contains关键字。但同样的,在Linq to Entities中会报不识别方法的错误。

解决思路1:先转化成集合,再来使用外部/扩展方法

解决思路2:使用集合的Any方法替换contains。(推荐)

[c-sharp] view plain copy print ?
  1. //出错语句   
  2. var result = from r in _entities.GroupRightSet  
  3.             //里面直接定义集合是可以的   
  4.             where (new int[] { 1, 2, 3 }).Contains(r.Reports.rid)  
  5.             select r.Reports.rid;  
  6.   
  7.   
  8.   
  9. //解决方法1   
  10. var entityList = from r in _entities.GroupRightSet.ToList();  
  11. var result = from r in entityList  
  12.                where (new int[] { 1, 2, 3 }).Contains(r.rid)  
  13.              select r.rid;  
  14.   
  15. //解决方法2   
  16. var result = from r in _entities.GroupRightSet  
  17.             where (new int[] { 1, 2, 3 }).Any(c=>c==r.Reports.rid)  
  18.             select r.Reports.rid;  


            item = from x in item
                   where userseldataid.Any(c => x.DataIDs.Contains(c))
                   select x;

 

 

 var item = (from x in context.Sys_User
                                select new { x.ID, x.MayKey }).ToList().Select(z => z.ID.ToString() + z.MayKey.ToString())
                                .Where(m => m.ToString() == mapKey);

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值