有时候我们在Select(投影)一些列的时候可能很自然需要使用一些方法,比如下面的代码。
源数据gid是整形的,我们现在需要的结果是转换成string的一个集合,所以在select语句后面使用了ToString(),这在Linq to SQL或者Linq to Object都是没有问题的。但是在Linq to Entities的时候会在运行时报错:LINQ to Entities 不识别方法“System.String ToString()”,无法将表达式转换云云。
此举据说是为了支持更多种类的数据库。不管出于什么原因不支持,几个地方表现不一致确实让人挺纠结的。不过问题还是得解决。怎么做比较简单呢?请看下面的代码:
在这句代码中,使用了Select这个扩展方法,把最后的结果一下子转换成了string,简洁方便。
需要注意的地方是中间有个ToList()。如果你不加ToList()直接接上Select扩展方法