多列查询到单个列子查询

时间:2016-01-22 14:55:45

标签: sql oracle

我有一个查询,它会生成一个人捐赠超过一年的名称和总金额列表。看起来像这样

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"

任何建议/提示将不胜感激:)

2 个答案:

答案 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

注意:WIT​​HING GROUP的order by子句中的值就像结果行之间的连接键一样。