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

在SQL Server 2005中實(shí)現(xiàn)表的行列轉(zhuǎn)換

系統(tǒng) 1807 0
PIVOT和UNPIVOT關(guān)系運(yùn)算符是SQL Server 2005提供的新增功能,因此,對升級到SQL Server 2005的數(shù)據(jù)庫使用PIVOT和UNPIVOT時,數(shù)據(jù)庫的兼容級別必須設(shè)置為90(可以使用sp_dbcmptlevel存儲過程設(shè)置兼容級別)。
在查詢的FROM子句中使用PIVOT和UNPIVOT,可以對一個輸入表值表達(dá)式執(zhí)行某種操作,以獲得另一種形式的表。PIVOT運(yùn)算符將輸入表的行旋轉(zhuǎn)為列,并能同時對行執(zhí)行聚合運(yùn)算。而UNPIVOT運(yùn)算符則執(zhí)行與PIVOT運(yùn)算符相反的操作,它將輸入表的列旋轉(zhuǎn)為行。
在FROM子句中使用PIVOT和UNPIVOT關(guān)系運(yùn)算符時的語法格式如下:
[ FROM { <table_source> } [ ,...n ] ]
<table_source> ::=
{
table_or_view_name [ [ AS ] table_alias ]
<pivoted_table> | <unpivoted_table>
}
<pivoted_table> ::=
table_source PIVOT <pivot_clause> table_alias
<pivot_clause> ::=
( aggregate_function ( value_column )
FOR pivot_column
IN ( <column_list> )
)
<unpivoted_table> ::=
table_source UNPIVOT <unpivot_clause> table_alias
<unpivot_clause> ::=
( value_column FOR pivot_column IN ( <column_list> ) )
<column_list> ::=
column_name [ , ... ]
table_source PIVOT <pivot_clause>
指定對table_source表中的pivot_column列進(jìn)行透視。table_source可以是一個表、表表達(dá)式或子查詢。
aggregate_function
系統(tǒng)或用戶定義的聚合函數(shù)。注意:不允許使用COUNT(*)系統(tǒng)聚合函數(shù)。
value_column
PIVOT運(yùn)算符用于進(jìn)行計(jì)算的值列。與UNPIVOT一起使用時,value_column不能是輸入table_source中的現(xiàn)有列的名稱。
FOR pivot_column
PIVOT運(yùn)算符的透視列。pivot_column必須是可隱式或顯式轉(zhuǎn)換為nvarchar()的類型。
使用UNPIVOT時,pivot_column是從table_source中提取輸出的列名稱,table_source中不能有該名稱的現(xiàn)有列。
IN ( column_list )
在PIVOT子句中,column_list列出pivot_column中將成為輸出表的列名的值。
在UNPIVOT子句中,column_list列出table_source中將被提取到單個pivot_column中的所有列名。
table_alias
輸出表的別名。
UNPIVOT < unpivot_clause >
指定將輸入表中由column_list指定的多個列的值縮減為名為pivot_column的單個列。
常見的可能會用到PIVOT的情形是:需要生成交叉表格報(bào)表以匯總數(shù)據(jù)。交叉表是使用較為廣泛的一種表格式,例如,圖5-4所示的產(chǎn)品銷售表就是一個典型的交叉表,其中的月份和產(chǎn)品種類都可以繼續(xù)添加。但是,這種格式在進(jìn)行數(shù)據(jù)表存儲的時候卻并不容易管理,要存儲圖5-4這樣的表格數(shù)據(jù),數(shù)據(jù)表通常需要設(shè)計(jì)為圖5-5這樣的結(jié)構(gòu)。這樣就帶來一個問題,用戶既希望數(shù)據(jù)容易管理,又希望能夠生成一種能夠容易閱讀的表格數(shù)據(jù)。好在PIVOT為這種轉(zhuǎn)換提供了便利。
圖5-4 產(chǎn)品銷售表 圖5-5 數(shù)據(jù)表結(jié)構(gòu)
假設(shè)Sales.Orders表中包含有ProductID(產(chǎn)品ID)、OrderMonth(銷售月份)和SubTotal(銷售額)列,并存儲有如表5-2所示的內(nèi)容。
表5-2 Sales.Orders 表中的內(nèi)容
ProductID
OrderMonth
SubTotal
1
5
100.00
1
6
100.00
2
5
200.00
2
6
200.00
2
7
300.00
3
5
400.00
3
5
400.00
執(zhí)行下面的語句:
SELECT ProductID, [5] AS 五月, [6] AS 六月, [7] AS 七月
FROM
Sales.Orders PIVOT
(
SUM (Orders.SubTotal)
FOR Orders.OrderMonth IN
( [5], [6], [7] )
) AS pvt
ORDER BY ProductID;
在上面的語句中,Sales.Orders是輸入表,Orders.OrderMonth是透視列(pivot_column),Orders.SubTotal是值列(value_column)。上面的語句將按下面的步驟獲得輸出結(jié)果集:
a.PIVOT首先按值列之外的列(ProductID和OrderMonth)對輸入表Sales.Orders進(jìn)行分組匯總,類似執(zhí)行下面的語句:
SELECT ProductID,
OrderMonth,
SUM (Orders.SubTotal) AS SumSubTotal
FROM Sales.Orders
GROUP BY ProductID,OrderMonth;
這時候?qū)⒌玫揭粋€如表5-3所示的中間結(jié)果集。其中只有ProductID為3的產(chǎn)品由于在5月有2筆銷售記錄,被累加到了一起(值為800)。
表5-3 Sales.Orders 表經(jīng)分組匯總后的結(jié)果
ProductID
OrderMonth
SumSubTotal
1
5
100.00
1
6
100.00
2
5
200.00
2
6
200.00
2
7
300.00
3
5
800.00
b.PIVOT根據(jù)FOR Orders.OrderMonth IN指定的值5、6、7,首先在結(jié)果集中建立名為5、6、7的列,然后從圖5-3所示的中間結(jié)果中取出OrderMonth列中取出相符合的值,分別放置到5、6、7的列中。此時得到的結(jié)果集的別名為pvt(見語句中AS pvt的指定)。結(jié)果集的內(nèi)容如表5-4所示。
表5-4 使用FOR Orders.OrderMonth IN( [5], [6], [7] )后得到的結(jié)果集
ProductID
5
6
7
1
100.00
100.00
NULL
2
200.00
200.00
200.00
3
800.00
NULL
NULL
c.最后根據(jù)SELECT ProductID, [5] AS 五月, [6] AS 六月, [7] AS 七月FROM的指定,從別名pvt結(jié)果集中檢索數(shù)據(jù),并分別將名為5、6、7的列在最終結(jié)果集中重新命名為五月、六月、七月。這里需要注意的是FROM的含義,其表示從經(jīng)PIVOT關(guān)系運(yùn)算符得到的pvt結(jié)果集中檢索數(shù)據(jù),而不是從Sales.Orders中檢索數(shù)據(jù)。最終得到的結(jié)果集如表5-5所示。
表5-5 由表5-2所示的Sales.Orders表將行轉(zhuǎn)換為列得到的最終結(jié)果集
ProductID
五月
六月
七月
1
100.00
100.00
NULL
2
200.00
200.00
200.00
3
800.00
NULL
NULL
UNPIVOT與PIVOT執(zhí)行幾乎完全相反的操作,將列轉(zhuǎn)換為行。但是,UNPIVOT并不完全是PIVOT的逆操作,由于在執(zhí)行PIVOT過程中,數(shù)據(jù)已經(jīng)被進(jìn)行了分組匯總,所以使用UNPIVOT并不會重現(xiàn)原始表值表達(dá)式的結(jié)果。假設(shè)表5-5所示的結(jié)果集存儲在一個名為MyPvt的表中,現(xiàn)在需要將列標(biāo)識符“五月”、“六月”和“七月”轉(zhuǎn)換到對應(yīng)于相應(yīng)產(chǎn)品ID的行值(即返回到表5-3所示的格式)。這意味著必須另外標(biāo)識兩個列,一個用于存儲月份,一個用于存儲銷售額。為了便于理解,仍舊分別將這兩個列命名為OrderMonth和SumSubTotal。參考下面的語句:
CREATE TABLE MyPvt (ProductID int, 五月int, 六月 int, 七月int); --建立MyPvt表
GO
--將表5-5中所示的值插入到MyPvt表中
INSERT INTO MyPvt VALUES (1,100,100,0);
INSERT INTO MyPvt VALUES (2,200,200,200);
INSERT INTO MyPvt VALUES (3,800,0,0);
--執(zhí)行UNPIVOT
SELECT ProductID, OrderMonth, SubTotal
FROM
MyPvt UNPIVOT
(SubTotal FOR OrderMonth IN
( 五月, 六月, 七月)
)AS unpvt;
上面的語句將按下面的步驟獲得輸出結(jié)果集:
a.首先建立一個臨時結(jié)果集的結(jié)構(gòu),該結(jié)構(gòu)中包含MyPvt表中除IN (五月, 六月, 七月)之外的列,以及SubTotal FOR OrderMonth中指定的值列(SubTotal)和透視列(OrderMonth)。
b.將在MyPvt中逐行檢索數(shù)據(jù),將表的列名稱(在IN (五月, 六月, 七月)中指定)放入OrderMonth列中,將相應(yīng)的值放入到SubTotal列中。最后得到的結(jié)果集如表5-6所示。
表5-6 使用UNPIVOT得到的結(jié)果集
ProductID
OrderMonth
SubTotal
1
五月
100
1
六月
100
1
七月
0
2
五月
200
2
六月
200
2
七月
200
3
五月
800
3
六月
0
3
七月
0

在SQL Server 2005中實(shí)現(xiàn)表的行列轉(zhuǎn)換


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 99精品热线在线观看免费视频 | 欧美一级视频在线观看 | 最近更新在线中文字幕一页 | 五月天婷婷激情 | 免费一看一级毛片 | 国产成人综合一区精品 | 国产亚洲欧洲精品 | 国产欧美日韩精品一区二区三区 | 一级毛片私人影院老司机 | 一级影院 | 久草视频在线播放 | 国产欧美亚洲精品第二区首页 | 美国一级毛片免费看成人 | 97av免费视频 | 精产国品一二二区视 | 日本一本在线观看 | 天天干天天操天天干 | 最近中文字幕在线视频1 | 色吧五月婷婷 | 精品中文字幕乱码一区二区 | 亚洲一区在线免费观看 | 欧美成人免费xxx大片 | 澳门成人免费永久视频 | 日本毛片网 | 成人午夜私人影院入口 | 国产精品福利自产拍网站 | 日本一区色 | 一级成人 | 久久草精品 | 一级aa毛片| 国产一二三区精品 | 性欧美xo视频在线观看 | 青娱乐91视频 | 色偷偷亚洲 | 亚洲成在人线中文字幕 | 国产精品久久久久久 | 日本一级www乱码在线 | 全黄冷激性性视频 | 久久久久青草大香线综合精品 | 国产日韩久久久精品影院首页 | 日韩国产片 |