程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 在SQL Server 2005中實現表的行列轉換

在SQL Server 2005中實現表的行列轉換

編輯:關於SqlServer

PIVOT和UNPIVOT關系運算符是SQL Server 2005提供的新增功能,因此,對升級到SQL Server 2005的數據庫使用PIVOT和UNPIVOT時,數據庫的兼容級別必須設置為90(可以使用sp_dbcmptlevel存儲過程設置兼容級別)。

在查詢的FROM子句中使用PIVOT和UNPIVOT,可以對一個輸入表值表達式執行某種操作,以獲得另一種形式的表。PIVOT運算符將輸入表的行旋轉為列,並能同時對行執行聚合運算。而UNPIVOT運算符則執行與PIVOT運算符相反的操作,它將輸入表的列旋轉為行。

在FROM子句中使用PIVOT和UNPIVOT關系運算符時的語法格式如下:

[ 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列進行透視。table_source可以是一個表、表表達式或子查詢。

aggregate_function

系統或用戶定義的聚合函數。注意:不允許使用COUNT(*)系統聚合函數。

value_column

PIVOT運算符用於進行計算的值列。與UNPIVOT一起使用時,value_column不能是輸入table_source中的現有列的名稱。

FOR pivot_column

PIVOT運算符的透視列。pivot_column必須是可隱式或顯式轉換為nvarchar()的類型。

使用UNPIVOT時,pivot_column是從table_source中提取輸出的列名稱,table_source中不能有該名稱的現有列。

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的情形是:需要生成交叉表格報表以匯總數據。交叉表是使用較為廣泛的一種表格式,例如,圖5-4所示的產品銷售表就是一個典型的交叉表,其中的月份和產品種類都可以繼續添加。但是,這種格式在進行數據表存儲的時候卻並不容易管理,要存儲圖5-4這樣的表格數據,數據表通常需要設計為圖5-5這樣的結構。這樣就帶來一個問題,用戶既希望數據容易管理,又希望能夠生成一種能夠容易閱讀的表格數據。好在PIVOT為這種轉換提供了便利。

圖5-4 產品銷售表 圖5-5 數據表結構

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved