Oracle SQL-使用select为某些行生成聚合行
我有一张像下面这样的桌子Oracle SQL-使用select为某些行生成聚合行,sql,oracle,aggregate,rollup,Sql,Oracle,Aggregate,Rollup,我有一张像下面这样的桌子 |FILE| ID |PARENTID|SHOWCHILD|CAT1|CAT2|CAT3|TOTAL| |F1 | A1 | P1 | N | 3 | 2 | 6 | 11 | |F2 | A2 | P2 | N | 4 | 7 | 3 | 14 | |F3 | A3 | P1 | N | 3 | 1 | 1 | 5 | |F4 | LG1| | Y
|FILE| ID |PARENTID|SHOWCHILD|CAT1|CAT2|CAT3|TOTAL|
|F1 | A1 | P1 | N | 3 | 2 | 6 | 11 |
|F2 | A2 | P2 | N | 4 | 7 | 3 | 14 |
|F3 | A3 | P1 | N | 3 | 1 | 1 | 5 |
|F4 | LG1| | Y | 6 | 3 | 7 | 16 |
|F5 | LG2| | Y | 4 | 7 | 3 | 14 |
现在,如果我只想为showChild为“Y”的行查找cat1、cat2、cat3和total的合计(ie)并将其添加到结果集中,是否可能
|Tot | Res | Res | N | 10 | 10 | 10 | 30|
预期最终输出:
|FILE| ID |PARENTID|SHOWCHILD|CAT1|CAT2|CAT3|TOTAL|
|F1 | A1 | P1 | N | 3 | 2 | 6 | 11 |
|F2 | A2 | P2 | N | 4 | 7 | 3 | 14 |
|F3 | A3 | P1 | N | 3 | 1 | 1 | 5 |
|F4 | LG1| | Y | 6 | 3 | 7 | 16 |
|F5 | LG2| | Y | 4 | 7 | 3 | 14 |
|Tot | Res| Res | N | 10 | 10 | 10 | 30 |
在这里,我只考虑了showchild为“Y”的行,然后添加了Tot行(最后一行),并将其添加到结果集
我正在尝试不使用UNION的解决方案 我们非常感谢您对实现上述结果的任何帮助
谢谢。一种方法是使用工会:
WITH cte AS (
SELECT "FILE", ID, PARENTID, SHOWCHILD, CAT1, CAT2, CAT3, TOTAL, 1 AS position
FROM yourTable
UNION ALL
SELECT 'Tot', 'Res', 'Res', 'N', SUM(CAT1), SUM(CAT2), SUM(CAT3), SUM(TOTAL), 2
FROM yourTable
WHERE SHOWCHILD = 'Y'
)
SELECT "FILE", ID, PARENTID, SHOWCHILD, CAT1, CAT2, CAT3, TOTAL
FROM cte
ORDER BY
position,
"FILE";
您可以尝试使用
UNION
select FILE,ID ,PARENTID,SHOWCHILD,CAT1,CAT2,CAT3,TOTAL from table1
union
select 'Tot','Res','Res','N',sum(cat1), sum(cat2),sum(cat3), sum(total)
from table1 where SHOWCHILD='Y'
我知道你已经接受了答案,但你确实要求了一个不涉及工会的解决方案。一种解决方案是使用
分组集
分组集
允许您在查询中指定不同的分组级别,并在每个级别生成聚合。根据您的需求,您可以使用它为每个记录生成一个输出行加上一个“总计”行。函数GROUPING
可在表达式中用于标识每个输出行是在一个组中还是在另一个组中
例如,使用测试数据:
with input_data ("FILE", "ID", PARENTID, SHOWCHILD, CAT1, CAT2, CAT3, TOTAL ) AS (
SELECT 'F1','A1','P1','N',3,2,6,11 FROM DUAL UNION ALL
SELECT 'F2','A2','P2','N',4,7,3,14 FROM DUAL UNION ALL
SELECT 'F3','A3','P1','N',3,1,1,5 FROM DUAL UNION ALL
SELECT 'F4','LG1','','Y',6,3,7,16 FROM DUAL UNION ALL
SELECT 'F5','LG2','','Y',4,7,3,14 FROM DUAL )
SELECT decode(grouping("FILE"),1,'Tot',"FILE") "FILE",
decode(grouping("ID"),1,'Res',"ID") "ID",
decode(grouping(parentid),1, 'Res',parentid) parentid,
decode(grouping(showchild),1, 'N',showchild) showchild,
decode(grouping("FILE"),1,sum(decode(showchild,'Y',cat1,0)),sum(cat1)) cat1,
decode(grouping("FILE"),1,sum(decode(showchild,'Y',cat2,0)),sum(cat2)) cat2,
decode(grouping("FILE"),1,sum(decode(showchild,'Y',cat3,0)),sum(cat3)) cat3,
decode(grouping("FILE"),1,sum(decode(showchild,'Y',total,0)),sum(total)) total
from input_data
group by grouping sets (("FILE", "ID", parentid, showchild), ())
但这不会产生OP期望的输出。我正在尝试一个解决方案,谢谢您的回复。为了简单起见,我从一个表中给出了like-take,而在我的场景中,我将表内容放在一个大的子查询中。因此,如果我使用union,就好像使用子查询两次来生成结果一样,然后你问错了问题。我已经回答了你提出的实际问题。
+------+-----+-----+----------+-----------+------+------+------+-------+
| FILE | F2 | ID | PARENTID | SHOWCHILD | CAT1 | CAT2 | CAT3 | TOTAL |
+------+-----+-----+----------+-----------+------+------+------+-------+
| F1 | F1 | A1 | P1 | N | 3 | 2 | 6 | 11 |
| F2 | F2 | A2 | P2 | N | 4 | 7 | 3 | 14 |
| F3 | F3 | A3 | P1 | N | 3 | 1 | 1 | 5 |
| F4 | F4 | LG1 | - | Y | 6 | 3 | 7 | 16 |
| F5 | F5 | LG2 | - | Y | 4 | 7 | 3 | 14 |
| Tot | Tot | Res | Res | N | 10 | 10 | 10 | 30 |
+------+-----+-----+----------+-----------+------+------+------+-------+