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)與列轉行(UNPIVOT)SQL
- Oracle 11g Pivot函式實現行轉列Oracle函式
- SQL 行轉列 PIVOT 學習示例SQL
- Oracle SQL 內建函式大全(轉)OracleSQL函式
- SQL Server 內建轉換函式介紹SQLServer函式
- 使用Oracle 11g函式Pivot實現資料聚合行轉列Oracle函式
- Oracle內建SQL函式-分類整理大全(轉)OracleSQL函式
- Oracle SQL 內建函式大全OracleSQL函式
- Oracle行轉列的函式Oracle函式
- Hive行轉列函式Hive函式
- Oracle行轉列函式Oracle函式
- 強大的拉姆表示式轉Sql 類庫 - SqlSugar 隱藏功能之LambdaSqlSugar
- 內建函式函式
- webgl內建函式--指數函式Web函式
- webgl內建函式--通用函式Web函式
- MySQL 內建函式MySql函式
- hive內建函式Hive函式
- php 內建函式PHP函式
- Mysql內建函式MySql函式
- 14、內建函式函式
- awk內建函式函式
- SQL 行轉列,列轉行SQL
- 一個用功能強大的ODBC API 函式訪問資料庫類 (轉)API函式資料庫
- PL/SQL單行函式和組函式詳解(轉)SQL函式
- Python內建函式Python函式
- python 內建函式Python函式
- Pyhton內建函式大全函式
- Oracle 內建函式三Oracle函式
- Oracle 內建函式一Oracle函式
- Oracle 內建函式二Oracle函式
- 幾個重要的內建函式函式
- python的部分內建函式Python函式
- python內建函式-eval()函式與exec()函式的區別Python函式
- SQL列轉行SQL
- webgl內建函式--幾何函式與矩陣函式Web函式矩陣
- webgl內建函式--向量函式與紋理查詢函式Web函式
- Hive函式(內建函式+自定義標準函式UDF)Hive函式
- SQL Server中行列轉換 Pivot UnPivotSQLServer