oracle中行轉(zhuǎn)列LISTAGG()函數(shù)詳解及應(yīng)用實(shí)例
1.LISTAGG()函數(shù)作為普通函數(shù)使用時(shí)就是查詢出來的結(jié)果列轉(zhuǎn)為行
SELECT LISTAGG ( NAME_CHS, ',' ) within GROUP ( ORDER BY ROWNUM ) name FROM GSPUSER WHERE ROWNUM <= 10
2.LISTAGG()作為分組函數(shù)使用
例如,把每個(gè)班組下面的人員拼接成一行
SELECT b.MOMTEAMNAME, LISTAGG ( g.NAME_CHS, ',' ) WITHIN GROUP ( ORDER BY b.MOMTEAMNAME ) res FROM DGMOMPTDGMOMGLHQYBZGL b LEFT JOIN DGMOMPTABOUTUSERS u ON b.ID = u.PARENTID LEFT JOIN GSPUSER g ON u.MOMEMPLOYEEID = g.ID WHERE b.MOMDATASTATE = 0 AND u.MOMDATASTATE = 0 GROUP BY b.MOMTEAMNAME
3.LISTAGG()做分析函數(shù)使用
例如,查詢每個(gè)班組下面有哪些人,統(tǒng)計(jì)每組人數(shù)量
SELECT MOMTEAMNAME,RES,COUNT FROM( SELECT b.MOMTEAMNAME, LISTAGG ( g.NAME_CHS, ',' ) WITHIN GROUP ( ORDER BY b.MOMTEAMNAME ) over(partition by b.MOMTEAMNAME) res, count(g.NAME_CHS) over(partition by b.MOMTEAMNAME) count, row_number() over(partition by b.MOMTEAMNAME ORDER BY ROWNUM) rn FROM DGMOMPTDGMOMGLHQYBZGL b LEFT JOIN DGMOMPTABOUTUSERS u ON b.ID = u.PARENTID LEFT JOIN GSPUSER g ON u.MOMEMPLOYEEID = g.ID WHERE b.MOMDATASTATE = 0 AND u.MOMDATASTATE = 0 ) WHERE rn = 1
附:高級(jí)用法
listagg(XXX,’,’) within GROUP (order by XXX) over (partition by XXX) rank
示例
with temp as( select 500 population, '中國(guó)' nation ,'江蘇' city from dual union all select 1500 population, '中國(guó)' nation ,'上海' city from dual union all select 500 population, '中國(guó)' nation ,'北京' city from dual union all select 1000 population, '美國(guó)' nation ,'紐約' city from dual union all select 500 population, '美國(guó)' nation ,'波士頓' city from dual union all select 500 population, '日本' nation ,'東京' city from dual ) select population, nation, city, listagg(city,',') within GROUP (order by city) over (partition by nation) rank from temp復(fù)制
運(yùn)行結(jié)果
總結(jié)
到此這篇關(guān)于oracle中行轉(zhuǎn)列LISTAGG()函數(shù)詳解及應(yīng)用實(shí)例的文章就介紹到這了,更多相關(guān)oracle行轉(zhuǎn)列LISTAGG()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle中sql語句(+)符號(hào)代表連接的使用講解
今天小編就為大家分享一篇關(guān)于Oracle中sql語句(+)符號(hào)代表連接的使用講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-02-02如何使用GDAL庫(kù)的ogr2ogr將GeoJSON數(shù)據(jù)導(dǎo)入到PostgreSql中
本文主要介紹了PyTorch中的masked_fill函數(shù)的基本知識(shí)和使用方法,masked_fill函數(shù)接受一個(gè)輸入張量和一個(gè)布爾掩碼作為主要參數(shù),掩碼的形狀必須與輸入張量相同,掩碼操作根據(jù)掩碼中的布爾值在輸出張量中填充指定的值或保留輸入張量中的值2024-10-10oracle數(shù)據(jù)庫(kù)刪除數(shù)據(jù)Delete語句和Truncate語句的使用比較
oracle當(dāng)表中的數(shù)據(jù)不需要時(shí),則應(yīng)該刪除該數(shù)據(jù)并釋放所占用的空間,刪除表中的數(shù)據(jù)可以使用Delete語句或者Truncate語句,下面分別介紹2012-09-09解決pl/sql developer中數(shù)據(jù)庫(kù)插入數(shù)據(jù)亂碼問題(SSM項(xiàng)目開發(fā))
這篇文章主要介紹了解決pl/sql developer中數(shù)據(jù)庫(kù)插入數(shù)據(jù)亂碼問題,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11oracle定時(shí)備份壓縮的實(shí)現(xiàn)步驟
本篇文章是對(duì)oracle定時(shí)備份壓縮的實(shí)現(xiàn)步驟進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05Oracle數(shù)據(jù)庫(kù)集復(fù)制方法淺議
Oracle數(shù)據(jù)庫(kù)集復(fù)制方法淺議...2007-03-03