))UNPIVOT用于將列明轉為列值(即列轉行),在SQLServer2000可以" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

sql內置函數pivot強大的行轉列功能

系統 1682 0
原文: 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

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

姓名 ? ? ? ? 課程 ? ? ? ? 分數
---------- ---------- -----------
張三 ? ? ? ? 語文 ? ? ? ? 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 行受影響)


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


sql內置函數pivot強大的行轉列功能


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 在线观看视频一区二区 | 欧美国产片 | 黄色亚洲毛片 | 香蕉视频在线免费看 | 久草视频福利在线观看 | 国产区欧美| 奇米影视久久777中文字幕 | 亚洲精品乱码国产精品乱码 | 夜色资源站www国产在线资源 | se999se男人最爱 | 中文字幕亚洲色图 | 国语国产真人对白毛片 | 亚洲国产午夜精品理论片的软件 | 99精品久久久久中文字幕 | 日日摸日日添夜夜爽97 | 亚洲欧美综合久久 | 中文字幕日韩亚洲 | 久久女人 | 香蕉视频亚洲 | 羞羞网站视频 | 天天干在线观看 | 久青草青综合在线视频 | 日韩在线中文 | 日日撸| 91在线精品老司机免费播放 | 亚洲欧美日韩综合一区久久 | 亚洲成人在线视频播放 | 奇米影视奇米四色888av | 亚洲综合网站久久久 | 男人草女人视频 | 毛片毛片毛片毛片出来毛片 | 亚洲综合国产 | 激情五月婷婷综合 | 男女很黄很色床视频网站免 | 日本黄色不卡视频 | 欧美久久久久久 | se94se在线看片secom | 国产精品久久毛片蜜月 | 久久视频精品36线视频在线观看 | 日本高清一级做a爱过程免费视频 | 精品91自产拍在线观看99re |