你可能知道如何在單個表上使用 LISTAGG(),但不知道如何在多個連接表上使用 LISTAGG。此示例演示如何在 Oracle 12g 中對連接的多個表使用聚合函數(shù)。
假設我們有以下兩個表。
“用戶”表
ID | 姓名 |
111 | aaa |
222 | bbb |
333 | bbb |
“記錄”表
ID | 標簽 | 價值 |
111 | start | 1 |
111 | mid | 2 |
111 | end | 3 |
222 | start | 1 |
222 | end | 2 |
333 | start | 1 |
333 | mid | 2 |
333 | start | 3 |
如果我們要選擇所有標有“start”和“end”的值,如下圖,sql查詢怎么寫?
預期結果:
ID | 姓名 | 聚合值 |
111 | aaa | 1,3 |
222 | bbb | 1,2 |
333 | bbb | 1,3 |
select u.ID, u.Name, listagg(Value, ', ') within group (order by Tag) as AggValues
from User u
left outer join Record r
on u.ID = r.ID and r.Tag in ('start', 'end')
group by u.ID, u.Name;
一個常見的錯誤是缺少最后一個 ?group by
? 子句中的字段。每個選擇字段也應該在 ?group by
? 子句中。在本例中,我們選擇 ?select
? ID 和 Name,因此應該使用 ID 和 Name 對結果進行分組。