gpt4 book ai didi

linq - 将包含 'with' cte的sql语句转换为linq

转载 作者:太空宇宙 更新时间:2023-11-03 14:55:15 24 4
gpt4 key购买 nike

我这里有这段代码,已经和它抗争了几个小时。基本上这个 sql 语句所做的是获取指定文件夹 (@compositeId) 的 ALL 子文件夹。

WITH auto_table (id, Name, ParentID) AS
(
SELECT
C.ID, C.Name, C.ParentID
FROM Composite_Table AS C
WHERE C.ID = @compositeId

UNION ALL

SELECT
C.ID, C.Name, C.ParentID
FROM Composite_Table AS C
INNER JOIN auto_table AS a_t ON C.ParentID = a_t.ID
)

SELECT * FROM auto_table

这个查询会返回这样的东西:

Id   |    Name    | ParentId
1 | StartFolder| NULL
2 | Folder2 | 1
4 | Folder3 | 1
5 | Folder4 | 4

现在我想将代码转换为 linq。我知道它涉及某种形式的递归,但由于 with 语句仍然卡住了。

最佳答案

没有 Linq to SQL 等效项可以(以有效的方式)做到这一点。最佳解决方案是从包含该语句的 Linq 调用 SP/View/UDF。

关于linq - 将包含 'with' cte的sql语句转换为linq,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49705439/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com