如果不首先将lambda表达式转换为委托或表达式树类型,则不能将lambda表达式用作动态分派的操作的参数

时间:2014-11-27 11:23:48

标签: c# linq lambda .net-4.5

我正在使用.NET4.5和VS2013,我有这个查询从db得到dynamic结果。

dynamic topAgents = this._dataContext.Sql(
    "select t.create_user_id as \"User\", sum(t.netamount) as \"Amount\" from transactiondetail t where t.update_date > sysdate -7 group by t.create_user_id")
    .QueryMany<dynamic>();

以下语句因编译错误Cannot use a lambda expression as an argument to a dynamically dispatched operation without first casting it to a delegate or expression tree type而失败 甚至不允许我运行它

topAgents.ToList().Select(agent => new
{
    User = agent.User != null ? string.Format("{0}", agent.User).Replace("CORPNTGB\\", "") : null,
    Amount = agent.Amount
});

虽然这个foreach的工作正常。

var data = new List<List<object>>();
foreach (dynamic agent in topAgents)
{
    data.Add(new List<object>
    {
        agent.User != null ? string.Format("{0}", agent.User).Replace("CORPNTGB\\", "") : null,
        agent.Amount
    });
}

在我topAgents.ToList()之后,我可以将它们解释为等价,是因为我明确声明var data = new List<List<object>>();编译器允许第二个语句吗?

为什么编译器不允许LINQ选择,但允许每个`?

1 个答案:

答案 0 :(得分:80)

问题是topAgentsdynamic - 因此ToList()来电是动态的,Select也是如此。这有以下问题:

  1. 你不能将lambda表达式用于这样的动态调用;
  2. 动态调用无论如何都找不到扩展方法。
  3. 幸运的是,操作不需要是动态的,因为元素类型是动态的。你可以使用:

    IEnumerable<dynamic> topAgents = ...;
    

    ...或者只使用var。这两个都应该没问题。