WITH RECURSIVE cte(bmb01, bmb03, ima53) AS ( SELECT bmb01, bmb03, ima53 FROM DS_REPORT.ABMR801110755ERP WHERE bmb01 = 'A801' UNION ALL SELECT b.bmb01, b.bmb03, c.ima53 + b.ima53 FROM DS_REPORT.ABMR801110755ERP b JOIN cte c ON b.bmb01 = c.bmb03 ) SELECT bmb01,bmb03, SUM(ima53) AS total_cost FROM cte GROUP BY bmb01,bmb03; 缺失哪些关键字
时间: 2024-01-31 10:03:39 浏览: 23
这个 SQL 查询语句是使用 WITH RECURSIVE 关键字创建递归公共表表达式(CTE),其中 cte 是递归表的名称。递归表的查询分为两个部分:
1. 基本查询:查询 ABMR801110755ERP 表中 bmb01 = 'A801' 的记录,并将 bmb01、bmb03 和 ima53 列作为递归表的初始记录集。
2. 递归查询:基于递归表的结果集,使用 JOIN 子句将 ABMR801110755ERP 表中 bmb01 = c.bmb03 的记录与递归表连接,计算每个记录的成本 ima53,并将结果加到递归表中的 ima53 值上,以形成新的记录集。
最后,使用 SELECT 和 GROUP BY 子句从递归表中检索结果,其中 bmb01 和 bmb03 是分组列,SUM(ima53) 是总成本列。
因此,这个 SQL 查询语句并没有缺失任何关键字。
相关问题
WITH RECURSIVE cte(bmb01, bmb03, ima53) AS ( SELECT bmb01, bmb03, ima53 FROM DS_REPORT.ABMR801110755ERP WHERE bmb01 = 'A801' UNION ALL SELECT b.bmb01, b.bmb03, c.ima53 + b.ima53 FROM DS_REPORT.ABMR801110755ERP b JOIN cte c ON b.bmb01 = c.bmb03 ) SELECT bmb01,bmb03,SUM(ima53) AS total_cost FROM cte GROUP BY bmb01,bmb03;
这是一个使用递归查询的SQL语句。递归查询是指在查询过程中使用了自己查询自己的方式,通常用于处理树形结构数据,比如部门树、分类树等。
具体来说,这个SQL语句的作用是查询表DS_REPORT.ABMR801110755ERP中以'A801'为根节点的部门及其子部门的成本总和。其中,bmb01是部门编码,bmb03是部门的上级编码,ima53是部门的成本。
递归查询的过程如下:
1. 首先,从ABMR801110755ERP表中选取bmb01为'A801'的部门,将它的bmb01、bmb03和ima53三列作为结果集的一部分。
2. 然后,以这个部门为基础,再次从ABMR801110755ERP表中查询与它有关系的部门,也就是它的子部门,将这些子部门的bmb01、bmb03和ima53三列加入结果集。这里用到了UNION ALL关键字,表示两个查询结果集的并集。
3. 接下来,对于每个子部门,重复步骤2,查询它的子部门并将其加入结果集。这个过程将会一直持续下去,直到没有更多的子部门为止。
4. 最后,对结果集按照bmb01和bmb03进行分组,计算每个分组的ima53的总和,得到每个部门及其子部门的成本总和。
注意,这个查询使用了CTE(公共表达式)来定义递归查询的过程,CTE是一种在SQL语句中定义临时表的方式,常用于递归查询和复杂的分析查询。
如果我想对bmb01相同的ima53进行递归求和,应该如何修改
如果您想对bmb01相同的ima53进行递归求和,可以将上面的SQL语句做如下修改:
```
WITH RECURSIVE cte(bmb01, bmb03, ima53) AS (
SELECT bmb01, bmb03, ima53
FROM DS_REPORT.ABMR801110755ERP
WHERE bmb01 = 'A801'
UNION ALL
SELECT b.bmb01, b.bmb03, c.ima53 + b.ima53
FROM DS_REPORT.ABMR801110755ERP b
JOIN cte c ON b.bmb03 = c.bmb01
)
SELECT bmb01, SUM(ima53) AS total_cost
FROM cte
GROUP BY bmb01;
```
这里的修改有两点:
1. 在cte公共表达式中,将第二个SELECT语句中的ON条件由c.bmb03 = b.bmb01改为b.bmb03 = c.bmb01。这样做的目的是将每个部门的子部门的成本累加到其上级部门的成本中,从而实现对bmb01相同的ima53递归求和。
2. 在SELECT语句中,将GROUP BY子句中的bmb03去掉,只保留bmb01。这样做的目的是按照部门编码bmb01分组,并计算每个分组的ima53的总和,得到每个部门及其子部门的成本总和。