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

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

sql內(nèi)置函數(shù)pivot強(qiáng)大的行轉(zhuǎn)列功能

系統(tǒng) 1916 0
原文: sql內(nèi)置函數(shù)pivot強(qiáng)大的行轉(zhuǎn)列功能

語法:

PIVOT 用于將列值旋轉(zhuǎn)為列名(即行轉(zhuǎn)列),在SQL Server? 2000 可以用聚合函數(shù)配合 CASE 語句實現(xiàn)

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

完整語法:

table_source

PIVOT(

聚合函數(shù)( value_column

FOR pivot_column

IN(<column_list>)

)

?

UNPIVOT 用于將列明轉(zhuǎn)為列值(即列轉(zhuǎn)行),在 SQL Server 2000 可以用 UNION 來實現(xiàn)

完整語法:

table_source

UNPIVOT(

value_column

FOR pivot_column

IN(<column_list>)

)

?

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

-----------------------------------------------------------------------------------------華麗的分隔符-------------------------------------------------------------------------------------------------

最簡單的案例:一句話轉(zhuǎn)換

建表:

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

select * from tb

-------------------------------- 結(jié)果 ------------------------------------------------------------------------------------

姓名 ? ? ? ? 課程 ? ? ? ? 分?jǐn)?shù)
---------- ---------- -----------
張三 ? ? ? ? 語文 ? ? ? ? 74
張三 ? ? ? ? 數(shù)學(xué) ? ? ? ? 83
張三 ? ? ? ? 物理 ? ? ? ? 93
李四 ? ? ? ? 語文 ? ? ? ? 74
李四 ? ? ? ? 數(shù)學(xué) ? ? ? ? 84
李四 ? ? ? ? 物理 ? ? ? ? 94


(6 行受影響)



現(xiàn)在的問題是:我想根據(jù)姓名統(tǒng)計這個人的三門成績,即:姓名 ? 語文 ? 數(shù)學(xué) ?物理

首先看看使用case when end結(jié)構(gòu)的時候:


select 姓名,
?max(case 課程 when '語文' then 分?jǐn)?shù) else 0 end)語文,
?max(case 課程 when '數(shù)學(xué)'then 分?jǐn)?shù) else 0 end)數(shù)學(xué),
?max(case 課程 when '物理'then 分?jǐn)?shù) else 0 end)物理
from tb
group by 姓名

-------------------------------- 結(jié)果 ------------------------------------------------------------------------------------

姓名 ? ? ? ? 語文 ? ? ? ? ?數(shù)學(xué) ? ? ? ? ?物理
---------- ----------- ----------- -----------
李四 ? ? ? ? 74 ? ? ? ? ?84 ? ? ? ? ?94
張三 ? ? ? ? 74 ? ? ? ? ?83 ? ? ? ? ?93


(2 行受影響)


這個結(jié)果就是我們想要的,然后再看看使用pivot:


select * from tb pivot(max(分?jǐn)?shù)) for 課程 in (語文,數(shù)學(xué),物理))a

--------------------------------結(jié)果------------------------------------------------------------------------------------

姓名 ? ? ? ? 語文 ? ? ? ? ?數(shù)學(xué) ? ? ? ? ?物理
---------- ----------- ----------- -----------
李四 ? ? ? ? 74 ? ? ? ? ?84 ? ? ? ? ?94
張三 ? ? ? ? 74 ? ? ? ? ?83 ? ? ? ? ?93

(2 行受影響)


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


sql內(nèi)置函數(shù)pivot強(qiáng)大的行轉(zhuǎn)列功能


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲精品一区二区综合 | 成人欧美一区二区三区在线 | 九九精品视频一区二区三区 | 69一级毛片 | 一级欧美在线的视频 | 中国大陆高清aⅴ毛片 | 欧美成人欧美激情欧美风情 | 全黄毛片 | 操熟美女又肥又嫩的骚屁股 | 99久久精品国产自免费 | 午夜99| 韩国一级理黄论片 | 日韩区在线 | 日韩日b | 成人婷婷 | 日本免费不卡视频一区二区三区 | 黄色在线视频观看 | 欧美日韩中文字幕在线观看 | 久久经典免费视频 | 国产精品乱码免费一区二区 | 3www黄| 久久久久一级片 | 精品久久一区 | 爱操成人网 | 高清免费毛片 | 久久99亚洲精品久久频 | 亚洲免费人成在线视频观看 | 亚洲免费福利视频 | 国产亚洲精品福利在线 | 久久国产精品一国产精品 | 九九资源站 | 久久久不卡 | 亚洲精品欧美精品日韩精品 | www日日日 | 亚洲人成一区二区不卡 | 精品视自拍视频在线观看 | 天天操操操| 国产高清专区 | 成人在线免费观看 | 欧美做爰xxxⅹ在线视频hd | 欧美美女xnxx |