0

エンティティ フレームワークを使用してこのクエリを生成しようとしていますdbContext

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 には、id、parent_id の 2 つの列があります。

私はこれを試しました:

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();

しかし、次のエラーが発生するため、機能していません。

 Unable to create a constant value of type 'Menuitem'. Only primitive types ('such as Int32, String, and Guid') are supported in this context.

このクエリを生成する方法はありますか?

4

1 に答える 1

0

これを 2 つの単純なクエリに分割できます。

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());

私はそれがあなたがしようとしていたのと同じことをすると確信しています。実際には、次のような 1 つのクエリでこれを実行できます。

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 が返されたときに 1 回だけ実行されます。2 つのクエリのように見えますが、Linq は最終オブジェクトが要求するまでクエリを実行しません。

于 2012-05-09T22:36:37.530 に答える