我有一个查询,它会生成一个人捐赠超过一年的名称和总金额列表。看起来像这样
select ad1.adbdesg_name as "Desg_Name",
sum(ag1.agvglst_amt) as "Total_Amt"
from agvglst ag1 INNER JOIN adbdesg ad1 ON ag1.agvglst_desg = ad1.adbdesg_desg
where ag1.agvglst_pidm = 12345
and to_char(ag1.agvglst_gift_date,'YYYYMMDD') >= 20150101
and to_char(ag1.agvglst_gift_date,'YYYYMMDD') <= 20151231
group by ad1.adbdesg_name;
简单吧?我得到了正确的结果:
Desg_Name Total_Amt
Administrative Council Scholarship End Prin NS (65%) 16.9
Blount County Campus 240
Administrative Council Scholarship (35%) 9.1
Faculty Senate Scholarship 10
现在我的问题是我需要将它变成一个单行子查询,以便放入报告中,因为他们希望每个人都能看到他们的捐赠金额。
我做了一些研究,想也许我可以尝试使用listagg函数来实现这一点,但我不相信你可以这样使用聚合函数,因为不允许使用组函数。
select listagg('DESG: '|| adbdesg_name as "Desg_Name" ||' AMT: $' || sum(AGVGLST_AMT), ',')
WITHIN GROUP (ORDER BY AGVGLST_GIFT_DATE) "DesgHC2015"
任何建议/提示将不胜感激:)
答案 0 :(得分:1)
将查询包装在另一个将进行聚合的查询中:
SELECT listagg( total, ',') WITHIN GROUP (ORDER BY adbdesg_name) AS DesgHC2015
FROM (
select ad1.adbdesg_name,
'DESG: '|| ad1.adbdesg_name || ' AMT: $' || sum(ag1.agvglst_amt) as total
from agvglst ag1
INNER JOIN adbdesg ad1
ON ag1.agvglst_desg = ad1.adbdesg_desg
where ag1.agvglst_pidm = 12345
and EXTRACT( YEAR FROM ag1.agvglst_gift_date ) = 2015
group by ad1.adbdesg_name
)
答案 1 :(得分:0)
LISTAGG将合并来自多行的列值,在这种情况下你可以使用它,但是我可以看到你想要第一个
SELECT 'DESG: '|| adbdesg_name || ' AMT: $' || Total_amt as Descg_name FROM yourtable
这样你就会得到合并的列,现在你可以像这样使用listagg:
SELECT LISTAGG( Descg_name,',') WITHIN GROUP ( ORDER BY AGVGLST_GIFT_DATE)
FROM yourtable
注意:WITHING GROUP的order by子句中的值就像结果行之间的连接键一样。