0
我遇到了Oracle中的递归查询问题。SQL递归查询(Oracle)
我目前能够通过在SQL Server中使用CTE获得结果,但我必须修改Oracle的代码。
我正在使用的代码是
WITH n(portefeuille, client, level, opcvm, ca, iter) AS
(
SELECT
portefeuille, client, 0 as level, opcvm, ca,
CAST(',' + CAST(portefeuille AS varchar) + ',' AS varchar) AS iter
FROM
dbo.chiffres
WHERE
opcvm IS NULL
UNION ALL
SELECT
m.portefeuille, n.client, n.level+1, m.opcvm, m.ca + n.ca,
CAST(iter + CAST(m.portefeuille AS varchar) + ',' AS varchar) AS iter
FROM
dbo.chiffres AS m
INNER JOIN
n ON n.portefeuille = m.opcvm
)
SELECT DISTINCT
n.level, n.client, n.portefeuille, n.ca , n.opcvm, iter,
(SELECT COUNT(*)
FROM n T1
WHERE T1.iter LIKE '%,' + CAST(n.portefeuille AS varchar) + ',%') - 1 AS Subordinates
FROM
n, dbo.chiffres c
WHERE
((SELECT COUNT(*)
FROM n T1
WHERE T1.iter LIKE '%,' + CAST(n.portefeuille AS varchar) + ',%') - 1) = 0
ORDER BY
level
我认为我有权使用甲骨文通过连接“,但我不知道如何使用它。
事实上,在我的最终代码中,我应该使用“select .....”而不是表dbo.chiffres。
这样做的结果是 “选择......” 是(探微个例)
Client | portefeuille | CA | OPCVM
31054 | 024 | 140 | NULL
104900 | 034 |200 | 024
31054 | 006 | 10 | NULL
,而我要的是最后的结果
level | Client | portefeuille | CA | iter | subordinates
0 | 31054 | 034 | 340 | ,024,034, |0
1 | 31054 | 006 | 10 | ,006, |0
CTE在Oracle中工作(在文档中称为子查询分解子句) - 您应该可以轻松移植它。将'level'重命名为'lvl' - 'level'是分层查询中使用的关键字,不能用作别名。 – MT0
谢谢你的回答。我想我试过这个解决方案,但我得到了错误'缺少SELECT关键字'。事实上,我的问题有点复杂,因为我没有表dbo.chiffres,而是使用'select ....'来代替。这可能是问题的根源吗? – Lamia
我在帖子中添加了一些细节来解释更多我的问题。 – Lamia