假设我有两个实体:具有N:1关系的Ent和SubEnt。因此,这里有导航属性SubEnt.Ents和Ent.SubEnt。另外,我还定义了一些ObjectQuery:
ObjectQuery<SubEnt> se;如何创建从Ent中选择具有来自se的Ent.SubEnt的所有实体的ESQL查询?大概是这样的:
SELECT VALUE it FROM Ent WHERE Ent.SubEnt IN @p其中@p == se.它看起来像一个嵌套查询。但是这种语法是不正确的,因为“只支持标量类型”。
发布于 2011-11-21 17:16:37
一旦你有了ObjectQuery,你就不能把它传递回ESQL。因此,您要么必须使用ObjectQuery编写整个查询,而不能分隔se,要么必须使用ESQL语言本身。在后一种情况下,尝试如下所示:
var query = from e in context.Ents
join s in se on e.Ent.Id equals s.Id
select e;除非你的例子只是更大查询的一些简化,否则你也可以简单地尝试:
var query = se.SelectMany(s => s.Ents).Distinct();https://stackoverflow.com/questions/8205065
复制相似问题