SQL Server行列轉(zhuǎn)換的實現(xiàn)示例
在使用SQL Server數(shù)據(jù)庫的過程中我們經(jīng)常會遇到需要將行數(shù)據(jù)和列數(shù)據(jù)相互轉(zhuǎn)換顯示的問題。對于這個問題SQL Server數(shù)據(jù)庫有專門的內(nèi)置函數(shù)PIVOT(行轉(zhuǎn)列)、UNPIVOT(列轉(zhuǎn)行)可以解決。下面我們就來分析一下這兩個函數(shù)的使用方法。
一、行轉(zhuǎn)列PIVOT
1、語法
select * from 源表名 as 表別名pivot( 聚合函數(shù)(源表需要聚合顯示的列的字段名)for 源表數(shù)據(jù)中需要轉(zhuǎn)換為列名的列的字段名 in (轉(zhuǎn)換后的列名1,轉(zhuǎn)換后的列名2…))as 表別名
2、舉個例子
先創(chuàng)建一個作為數(shù)據(jù)源的表插入少量數(shù)據(jù):
create table StudentScores ( StudentName varchar(16), Subject varchar(16), Score smallint ) insert into StudentScores values('張三','語文',85) insert into StudentScores values('張三','數(shù)學',90) insert into StudentScores values('張三','英語',86) insert into StudentScores values('李四','語文',92) insert into StudentScores values('李四','數(shù)學',87) insert into StudentScores values('李四','英語',90)
此時 select * from StudentScores 直接查詢結(jié)果如下:
下面是我們使用PIVOT函數(shù)轉(zhuǎn)換后查詢出的結(jié)果,先看下代碼:
select * from StudentScores as s --源數(shù)據(jù) pivot(max(Score) for Subject in (語文,數(shù)學,英語)) as ss --轉(zhuǎn)換后的結(jié)果數(shù)據(jù)
查詢出的結(jié)果如圖:
二、列轉(zhuǎn)行UNPIVOT
1、語法
select * from 源表名 as 表別名
unpivot(定義由源表數(shù)據(jù)轉(zhuǎn)換成的列的列名 for 定義由源表字段名轉(zhuǎn)換成的列的列名 in
(源表字段名1,源表字段名2…)) as 表別名
2、實例
為求直觀直接用上面實例的結(jié)果數(shù)據(jù)創(chuàng)建一個新表:
create table StudentGrades ( StudentName varchar(16), 語文 smallint, 數(shù)學 smallint, 英語 smallint, ) insert into StudentGrades values('張三',85,90,86) insert into StudentGrades values('李四',92,87,90)
select * from StudentGrades直接查詢結(jié)果如下:
使用UNPIVOT函數(shù)進行轉(zhuǎn)換,代碼如下:
select * from StudentGrades as sg --源數(shù)據(jù) unpivot(Score for Subject in (語文,數(shù)學,英語)) as cjd --轉(zhuǎn)換后的結(jié)果數(shù)據(jù)
結(jié)果如圖:
和PIVOT函數(shù)的實例中源數(shù)據(jù)的表基本相同。當然我們也可以不創(chuàng)建新表直接使用以下代碼查詢出相同的結(jié)果:
select * from StudentScores as s pivot(max(Score) for Subject in (語文,數(shù)學,英語)) as ss unpivot(Score for Subject in (語文,數(shù)學,英語)) as cjd
通過上面的例子,我們簡單了解了PIVOT和UNPIVOT這兩個函數(shù)的使用方法,在例子中我們用這兩個函數(shù)實現(xiàn)了數(shù)據(jù)的行列逆轉(zhuǎn)查詢,雖然UNPIVOT函數(shù)可以將PIVOT函數(shù)轉(zhuǎn)換后的結(jié)果還原成轉(zhuǎn)換前的樣子,但UNPIVOT 并不完全是 PIVOT 的逆操作。 PIVOT 執(zhí)行聚合,并將多個可能的行合并為輸出中的一行。 UNPIVOT 不重現(xiàn)原始表值表達式的結(jié)果,因為行已被合并。 另外,UNPIVOT 輸入中的 NULL 值也在輸出中消失了。 如果值消失,表明在執(zhí)行 PIVOT 操作前,輸入中可能就已存在原始 NULL 值。
到此這篇關于SQL Server行列轉(zhuǎn)換的實現(xiàn)示例的文章就介紹到這了,更多相關SQL Server行列轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- sql 普通行列轉(zhuǎn)換
- 一個簡單的SQL 行列轉(zhuǎn)換語句
- sqlserver2005 行列轉(zhuǎn)換實現(xiàn)方法
- Sql實現(xiàn)行列轉(zhuǎn)換方便了我們存儲數(shù)據(jù)和呈現(xiàn)數(shù)據(jù)
- 玩轉(zhuǎn)-SQL2005數(shù)據(jù)庫行列轉(zhuǎn)換
- 深入SQL中PIVOT 行列轉(zhuǎn)換詳解
- PostgreSQL實現(xiàn)交叉表(行列轉(zhuǎn)換)的5種方法示例
- sql server通過pivot對數(shù)據(jù)進行行列轉(zhuǎn)換的方法
- SQL Server 使用 Pivot 和 UnPivot 實現(xiàn)行列轉(zhuǎn)換的問題小結(jié)
- SQL Server使用PIVOT與unPIVOT實現(xiàn)行列轉(zhuǎn)換
- MySQL實現(xiàn)行列轉(zhuǎn)換
- SQL行列轉(zhuǎn)換超詳細四種方法詳解
- SQLServer使用 PIVOT 和 UNPIVOT行列轉(zhuǎn)換
相關文章
SQL SERVER 數(shù)據(jù)庫備份的三種策略及語句
這篇文章主要介紹了SQL SERVER 數(shù)據(jù)庫備份的三種策略及語句,需要的朋友可以參考下2017-02-02在SQL Server中實現(xiàn)最短路徑搜索的解決方法
本篇文章小編為大家介紹,在SQL Server中實現(xiàn)最短路徑搜索的解決方法。需要的朋友參考下2013-04-04SQL Server數(shù)據(jù)庫自動收縮配置指南
在數(shù)據(jù)庫管理中,隨著數(shù)據(jù)的增刪,數(shù)據(jù)庫文件的大小會不斷變化,導致空間浪費和性能下降,SQL Server提供了自動收縮功能,本文將深入探討如何在SQL Server中配置數(shù)據(jù)庫的自動收縮,需要的朋友可以參考下2024-07-07sql 查詢結(jié)果合并union all用法_數(shù)據(jù)庫技巧
sql語句查詢結(jié)果合并union all用法_數(shù)據(jù)庫技巧,需要的朋友可以參考下。2009-11-11