假设我有一个看起来像这样的 OData 查询(我的实际查询要复杂得多):
Orders.Select(z => new { z.SubOrder.Addresses,
z.SubOrder.Cost,
z.SubOrder.SubOrderId,
z.Sequence});
这工作正常。除了 Address 对象上有一个子对象(StateRef)。由于 StateRef 对 State 表进行了查找,因此它返回为 null。
为了说明,下面是地址对象 Address 的示例:
Address:
string Street 1
string Street 2
StateRef PrimaryState
string City
// ... 42 other string attributes not shown ...
该StateRef
对象上面有状态的名称,但也有一些其他重要的状态属性(可能是状态鸟?)
所以,我想知道的是,我现在是否必须为包含所有 46 个属性的 z.SubOrder.Addresses 创建一个“子投影”,以便我可以访问该PrimaryState
项目?(我希望不是)
除了更多的编码之外,这还意味着我必须使用匿名类型。这使得我的映射必须手动(而不是使用 AutoMapper)。
那么我正在寻找一种在投影内“扩展”StateRef 的方法?
像这样的东西:
Orders.Select(z => new { z.SubOrder.Addresses.Expand("PrimaryState"),
z.SubOrder.Cost, ^
z.SubOrder.SubOrderId, |
z.Sequence}); |
|
// This is not allowed by the compiler ----------+
尝试这个会给出这个错误:
无效的匿名类型成员声明符。必须使用成员分配、简单名称或成员访问来声明匿名类型成员。
更新: 这是一个示例查询来说明我在问什么:
Users.Take(10).Select(x=>new { x.Id, x.Reputation, x.Comments})
针对“ data.stackexchange.com/stackoverflow/atom ”运行它。您将看到 Comments 有一个返回 null 的 Post 对象。
我需要它来返回其中的值。
注意:我知道我可以手动将它们全部输入到“子”投影中。阅读上面的内容,了解我不想要的原因。