The LINQ expression “xxx“ could not be translated
错误示例:
var A = B
.GroupBy(item => item.id)
.Select(groupedList => new
{
PlannerId = groupedList.Key,
RxList = groupedList
});
解决方案:
var A = B
.GroupBy(item => item.id)
.Select(groupedList => new
{
PlannerId = groupedList.Key,
RxList = groupedList.toList()
});
原因:
你的修改是正确的,并且解决了报错。让我解释一下为什么这个修改有效。
在原始代码中,你使用了GroupBy
操作符来根据item.id
对B
结果进行分组。然后,你使用Select
投影操作符创建一个新的匿名类型,其中包含了分组键(PlannerId)和分组的列表(RxList)。
然而,问题在于 LINQ 表达式无法直接翻译带有分组参数的Select
操作符。因为分组的列表返回的是一个 GroupedEnumerable
类型的对象,而不是标准的集合类型(如 List
或 Array
)。
通过执行 .ToList()
操作,我们将 GroupedEnumerable
类型的对象转换为 List
类型的对象。这样,在 Select
投影操作符中,我们就能够正确地对分组进行操作,因为它已经被组合起来进行了翻译。
所以,通过在 groupByPlannerIdQuaryable
的 Select
中调用 .ToList()
方法,你确保了分组的列表已经被组合起来,并且成功解决了报错。