sql內建函式pivot強大的行轉列功能

赤砂之蠍我愛羅發表於2012-11-05

語法:

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

--------------------------------結果------------------------------------------------------------------------------------

姓名         課程         分數
---------- ---------- -----------
張三         語文         74
張三         數學         83
張三         物理         93
李四         語文         74
李四         數學         84
李四         物理         94


(6 行受影響)



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

首先看看使用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 姓名

--------------------------------結果------------------------------------------------------------------------------------

姓名         語文          數學          物理
---------- ----------- ----------- -----------
李四         74          84          94
張三         74          83          93


(2 行受影響)


這個結果就是我們想要的,然後再看看使用pivot:


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

--------------------------------結果------------------------------------------------------------------------------------

姓名         語文          數學          物理
---------- ----------- ----------- -----------
李四         74          84          94
張三         74          83          93

(2 行受影響)


哇,結果一模一樣!這個就是我想用的結果。


相關文章