エンティティ フレームワークを使用してこのクエリを生成しようとしています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.
このクエリを生成する方法はありますか?