感覺還是蠻全的
/*
標題:普通行列轉換(version 2.0)問題:假設有張學生成績表(tb)如下:
姓名 課程 分數
張三 語文 74
張三 數學 83
張三 物理 93
李四 語文 74
李四 數學 84
李四 物理 94
想變成(得到如下結果):
姓名 語文 數學 物理
---- ---- ---- ----
李四 74 84 94
張三 74 83 93
-------------------
*/
createtable tb(姓名 varchar(10) , 課程 varchar(10) , 分數 int)
insertinto tb values('張三' , '語文' , 74)
insertinto tb values('張三' , '數學' , 83)
insertinto tb values('張三' , '物理' , 93)
insertinto tb values('李四' , '語文' , 74)
insertinto tb values('李四' , '數學' , 84)
insertinto tb values('李四' , '物理' , 94)
go
--SQL SERVER 2000 靜態SQL,指課程只有語文、數學、物理這三門課程。(以下同)
select姓名 as姓名 ,
max(case課程 when'語文'then分數 else0end) 語文,
max(case課程 when'數學'then分數 else0end) 數學,
max(case課程 when'物理'then分數 else0end) 物理
from tb
groupby姓名
--SQL SERVER 2000 動態SQL,指課程不止語文、數學、物理這三門課程。(以下同)
declare@sqlvarchar(8000)
set@sql='select 姓名 '
select@sql=@sql+' , max(case 課程 when '''+課程 +''' then 分數 else 0 end) ['+課程 +']'
from (selectdistinct課程 from tb) as a
set@sql=@sql+' from tb group by 姓名'
exec(@sql)
--SQL SERVER 2005 靜態SQL。
select*from (select*from tb) a pivot (max(分數) for課程 in (語文,數學,物理)) b
--SQL SERVER 2005 動態SQL。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+',' , '') +課程 from tb groupby課程
exec ('select * from (select * from tb) a pivot (max(分數) for 課程 in ('+@sql+')) b')
---------------------------------
/*
問題:在上述結果的基礎上加平均分,總分,得到如下結果:
姓名 語文 數學 物理 平均分 總分
---- ---- ---- ---- ------ ----
李四 74 84 94 84.00 252
張三 74 83 93 83.33 250
*/
--SQL SERVER 2000 靜態SQL。
select姓名 姓名,
max(case課程 when'語文'then分數 else0end) 語文,
max(case課程 when'數學'then分數 else0end) 數學,
max(case課程 when'物理'then分數 else0end) 物理,
cast(avg(分數*1.0) asdecimal(18,2)) 平均分,
sum(分數) 總分
from tb
groupby姓名
--SQL SERVER 2000 動態SQL。
declare@sqlvarchar(8000)
set@sql='select 姓名 '
select@sql=@sql+' , max(case 課程 when '''+課程 +''' then 分數 else 0 end) ['+課程 +']'
from (selectdistinct課程 from tb) as a
set@sql=@sql+' , cast(avg(分數*1.0) as decimal(18,2)) 平均分 , sum(分數) 總分 from tb group by 姓名'
exec(@sql)
--SQL SERVER 2005 靜態SQL。
select m.* , n.平均分 , n.總分 from
(select*from (select*from tb) a pivot (max(分數) for課程 in (語文,數學,物理)) b) m,
(select姓名 , cast(avg(分數*1.0) asdecimal(18,2)) 平均分 , sum(分數) 總分 from tb groupby姓名) n
where m.姓名 = n.姓名
--SQL SERVER 2005 動態SQL。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+',' , '') +課程 from tb groupby課程
exec ('select m.* , n.平均分 , n.總分 from
(select * from (select * from tb) a pivot (max(分數) for 課程 in ('+@sql+')) b) m ,
(select 姓名 , cast(avg(分數*1.0) as decimal(18,2)) 平均分 , sum(分數) 總分 from tb group by 姓名) n
where m.姓名 = n.姓名')
droptable tb
------------------
------------------
/*
問題:如果上述兩表互相換一下:即表結構和數據爲:
姓名 語文 數學 物理
張三 74 83 93
李四 74 84 94
想變成(得到如下結果):
姓名 課程 分數
---- ---- ----
李四 語文 74
李四 數學 84
李四 物理 94
張三 語文 74
張三 數學 83
張三 物理 93
--------------
*/
createtable tb(姓名 varchar(10) , 語文 int , 數學 int , 物理 int)
insertinto tb values('張三',74,83,93)
insertinto tb values('李四',74,84,94)
go
--SQL SERVER 2000 靜態SQL。
select*from
(
select姓名 , 課程 ='語文' , 分數 =語文 from tb
unionall
select姓名 , 課程 ='數學' , 分數 =數學 from tb
unionall
select姓名 , 課程 ='物理' , 分數 =物理 from tb
) t
orderby姓名 , case課程 when'語文'then1when'數學'then2when'物理'then3end
--SQL SERVER 2000 動態SQL。
--調用系統表動態生態。
declare@sqlvarchar(8000)
select@sql=isnull(@sql+' union all ' , '' ) +' select 姓名 , [課程] = '+quotename(Name , '''') +' , [分數] = '+quotename(Name) +' from tb'
from syscolumns
where name! = N'姓名'and ID =object_id('tb') --表名tb,不包含列名爲姓名的其它列
orderby colid asc
exec(@sql+' order by 姓名 ')
--SQL SERVER 2005 動態SQL。
select姓名 , 課程 , 分數 from tb unpivot (分數 for課程 in([語文] , [數學] , [物理])) t
--SQL SERVER 2005 動態SQL,同SQL SERVER 2000 動態SQL。
--------------------
/*
問題:在上述的結果上加個平均分,總分,得到如下結果:
姓名 課程 分數
---- ------ ------
李四 語文 74.00
李四 數學 84.00
李四 物理 94.00
李四 平均分 84.00
李四 總分 252.00
張三 語文 74.00
張三 數學 83.00
張三 物理 93.00
張三 平均分 83.33
張三 總分 250.00
------------------
*/
select*from
(
select姓名 as姓名 , 課程 ='語文' , 分數 =語文 from tb
unionall
select姓名 as姓名 , 課程 ='數學' , 分數 =數學 from tb
unionall
select姓名 as姓名 , 課程 ='物理' , 分數 =物理 from tb
unionall
select姓名 as姓名 , 課程 ='平均分' , 分數 =cast((語文 +數學 +物理)*1.0/3asdecimal(18,2)) from tb
unionall
select姓名 as姓名 , 課程 ='總分' , 分數 =語文 +數學 +物理 from tb
) t
orderby姓名 , case課程 when'語文'then1when'數學'then2when'物理'then3when'平均分'then4when'總分'then5end
droptable tb