Oracle中pivot函數(shù)圖文實例詳解
【基本介紹】
【格式】:pivot(聚合函數(shù) for 需要轉(zhuǎn)為列的字段名 in(需要轉(zhuǎn)為列的字段值))
【說明】:實現(xiàn)將指定字段的字段值轉(zhuǎn)換為列的效果。
【環(huán)境】:如下圖是樣例展示所使用的oracle版本。

【準備樣例數(shù)據(jù)】
樣例數(shù)據(jù)如下圖所示:
NAME-學生姓名,SUBJECT-考試科目,GRADES-考試成績。

【樣例展示1】
實行如下sql語句:
select * from T_Student_Grades
pivot
(
sum(grades)
for name in('張三','李四','王五')
)返回結(jié)果如下:按指定科目統(tǒng)計所有學生的總成績,并將學生姓名字段行轉(zhuǎn)列顯示(此時雖然用到了聚合函數(shù)sum,由于SUBJECT字段也一并顯示,因此sum函數(shù)并沒有起到效果,顯示依舊是每一個學生的各科具體成績)。

【樣例展示2】
實行如下sql語句:
select * from T_Student_Grades
pivot
(
avg(grades)
for name in ('張三' as 張三,'李四' as 李四,'王五' as 王五)
)返回結(jié)果如下:按指定科目統(tǒng)計所有學生的平均成績,并將學生姓名字段行轉(zhuǎn)列,顯示別名(此時雖然用到了聚合函數(shù)avg,由于SUBJECT字段也一并顯示,因此avg函數(shù)并沒有起到效果,顯示依舊是每一個學生的各科具體成績)。

【樣例展示3】
實行如下sql語句:
select * from (select name,grades from T_Student_Grades)
pivot
(
sum(grades)
for name in ('張三','李四','王五')
)返回結(jié)果如下:統(tǒng)計每一個學生的所有科目總成績,并將學生姓名字段行轉(zhuǎn)列(SUBJECT字段沒有顯示)。

【樣例展示4】
實行如下sql語句:
select * from T_Student_Grades
pivot
(
max(grades)
for name in ('張三' as 張三,'李四' as 李四,'王五' as 王五)
)
where subject='數(shù)學'返回結(jié)果如下:按指定科目統(tǒng)計所有學生的最高成績,并將學生姓名字段行轉(zhuǎn)列,并且只顯示數(shù)學這一科目的成績(此時雖然用到了聚合函數(shù)max,由于SUBJECT字段也一并顯示,因此max函數(shù)并沒有起到效果,依舊是顯示每一個學生的各科具體成績)。

【樣例展示5】
實行如下sql語句:
?select * from T_Student_Grades
pivot
(
min(grades)
for name in ('張三' as 張三,'李四' as 李四,'王五' as 王五)
)
where 張三='90'返回結(jié)果如下:按指定科目統(tǒng)計所有學生的最低成績,并將學生姓名字段行轉(zhuǎn)列,并且只顯示數(shù)學這一科目的成績(此時雖然用到了聚合函數(shù)max,由于SUBJECT字段也一并顯示,因此max函數(shù)并沒有起到效果,依舊是顯示每一個學生的各科具體成績)。

【樣例展示6】
實行如下sql語句(in中使用子查詢):
select * from T_Student_Grades pivot ( count(grades) for name in (select distinct name from T_Student_Grades) )
報錯提示:ORA-00936:確實表達式,如下圖所示,看來in不支持子查詢。

總結(jié)
到此這篇關(guān)于Oracle中pivot函數(shù)詳解的文章就介紹到這了,更多相關(guān)Oracle pivot函數(shù)詳解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Oracle數(shù)據(jù)IMP和EXP命令用法詳解
這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)IMP和EXP命令用法詳解的相關(guān)資料,我們可以使用Oracle自帶的exp、imp命令來進行數(shù)據(jù)庫備份,imp和exp稱之為導入導出,這種方式也能快速的導入導出table或數(shù)據(jù)庫,需要的朋友可以參考下2023-11-11
Oracle數(shù)據(jù)庫中基本的查詢優(yōu)化與子查詢優(yōu)化講解
這篇文章主要介紹了Oracle數(shù)據(jù)庫中基本的查詢優(yōu)化與子查詢優(yōu)化講解,舉了實例來分析子查詢對性能的影響,需要的朋友可以參考下2016-01-01
Oracle數(shù)據(jù)庫正則表達式純數(shù)字例子
正則表達式已經(jīng)在很多軟件中得到廣泛的應用,包括*nix(Linux, Unix等),HP等操作系統(tǒng),PHP,C#,Java等開發(fā)環(huán)境,這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫正則表達式純數(shù)字的相關(guān)資料,需要的朋友可以參考下2024-08-08
Hibernate Oracle sequence的使用技巧
本文介紹了關(guān)于Hibernate中如何使用Oracle sequence的問題以及應注意的事項。2009-06-06

