我有以下代码:
using (DBContext context = new DBContext())
{
myCollection = context.Items.Where(i => i.Type == 1).OrderBy(k => k.Name).Select(w => new
{
Alias = w.Name + string.Format("{0}", w.Id),
Name = w.Name
}).ToArray();
}
在运行时我尝试连接字符串并尝试将整数 w.Id 转换为字符串时出现错误。
错误说:
Linq to entity 无法识别方法 string.Format
也不支持加连接符号“+”。
我通过引入 AsEnumerable 解决了这个问题:
using (DBContext context = new DBContext())
{
myCollection = context.Items.AsEnumerable().Where(i => i.Type == 1).OrderBy(k => k.Name).Select(w => new
{
Alias = w.Name + string.Format("{0}", w.Id),
Name = w.Name
}).ToArray();
}
但我想知道这是否是最好的解决方案,或者还有另一种更适合这样做的方法。想法?