首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Entity Framework4.1中生成子查询where-in查询

如何在Entity Framework4.1中生成子查询where-in查询
EN

Stack Overflow用户
提问于 2012-05-10 05:50:13
回答 1查看 645关注 0票数 0

我正在尝试使用实体框架dbContext生成以下查询:

代码语言:javascript
复制
SELECT     id
FROM         menuitems
WHERE     (parent_id = 11)
UNION
SELECT     id
FROM         menuitems AS menuitems_2
WHERE     (parent_id IN
    (SELECT     id
    FROM          menuitems AS menuitems_1
    WHERE      (parent_id = 11)))

表menuitems有2列: id、parent_id

我试过这个:

代码语言:javascript
复制
List<int> mi = ctx.MenuItems.Where(i => i.parent_id == this.id).Select(id => id.id)
.Union(ctx.MenuItems.Where(c => ctx.MenuItems
              .Where(i => i.parent_id == this.id).Select(id => id.id)
              .Contains((int)c.parent_id)).Select(id => id.id))
              .ToList();

但它不工作,因为我得到了以下错误:

代码语言:javascript
复制
 Unable to create a constant value of type 'Menuitem'. Only primitive types ('such as Int32, String, and Guid') are supported in this context.

有没有办法生成这个查询?

EN

回答 1

Stack Overflow用户

发布于 2012-05-10 06:36:38

您可以将其分解为两个更简单的查询:

代码语言:javascript
复制
List<int> allItems=new List<int>();
var items= menuitems.Where(m=>m.parent_id == 11).Select(m=>m.id);
var children= menuitems.Where(items.Contains(m=>m.parent_id)).Select(m=>m.id);
allItems.AddRange(items.ToList());
allItems.AddRange(children.ToList());

我很确定这和你想要做的事情是一样的。实际上,您可以像这样使用一个查询来执行此操作:

代码语言:javascript
复制
List<int> allItems=new List<int>();
var items= menuitems.Where(m=>m.parent_id == 11).Select(m=>m.id)
allItems= items.Union(menuitems.Where(items.Contains(m=>m.parent_id)).Select(m=>m.id));

此查询仅在返回allItems时运行一次。即使看起来像是两个查询,Linq也不会运行查询,直到最后一个对象请求它。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10524594

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档