sql強大的行轉列功能(內置函數pivot及注意事項)


語法:

PIVOT用於將列值旋轉為列名(即行轉列),在SQL Server 2000可以用聚合函數配合CASE語句實現

PIVOT的一般語法是:PIVOT(聚合函數(列) FOR 列 in (…) )AS P

完整語法:

table_source

PIVOT(

聚合函數(value_column)

FOR pivot_column

IN(<column_list>)

)

UNPIVOT用於將列明轉為列值(即列轉行),在SQL Server 2000可以用UNION來實現

完整語法:

table_source

UNPIVOT(

value_column

FOR pivot_column

IN(<column_list>)

)

注意:PIVOT、UNPIVOT是SQL Server 2005 的語法,使用需修改數據庫兼容級別
 在數據庫屬性->選項->兼容級別改為   90

 

if object_id('tb')is not null drop table tb
go
create table tb(姓名 varchar(10),課程 varchar(10),分數 int)
insert into tb values('張三','語文',74)
insert into tb values('張三','數學',83)
insert into tb values('張三','物理',93)
insert into tb values('李四','語文',74)
insert into tb values('李四','數學',84)
insert into tb values('李四','物理',94)
go

select * from tb

 

 

方法一:

現在的問題是:我想根據姓名統計這個人的三門成績,即:姓名   語文   數學  物理

首先看看使用case when end結構的時候:

 

select 姓名,
 max(case 課程 when '語文' then 分數 else 0 end)語文,
 max(case 課程 when '數學'then 分數 else 0 end)數學,
 max(case 課程 when '物理'then 分數 else 0 end)物理
from tb
group by 姓名

方法二:使用pivot函數

select * from tb pivot(max(分數) for 課程 in (語文,數學,物理)) a

上面查詢前提是:

PIVOT、UNPIVOT是SQL Server 2005 的語法,使用需修改數據庫兼容級別
 在數據庫屬性->選項->兼容級別改為   90

如果兼容級別不改為 90 ,查詢結果如下:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM