SQL知識點之列轉行Unpivot函數

這篇文章主要給大家介紹了關於SQL知識點之列轉行Unpivot函數的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

這是總結SQL知識點的第二篇文章,一次只總結一個知識點,儘量說明白。上次我們談到行轉列,用的是Pivot函數,這次我們來談談Unpivot函數。(這裏是用的數據庫是SQLSERVER,與其他數據庫是類似的,大家放心看就好)

先看一個小問題CustomerCustomer

在這張圖中,表示的是顧客用不同手機號給Phone1、Phone2、Phone3撥打電話的情況,但是機靈的你,想變個花樣來看看,比如下面這樣的。

UnpivotUnpivot

大家想想看如何實現呢?想下,2分鐘後再看喲

先創建數據

 CREATE TABLE dbo.CustomerPhones
(
 CustomerID INT PRIMARY KEY, -- FK
 Phone1 VARCHAR(32),
 Phone2 VARCHAR(32),
 Phone3 VARCHAR(32)
);
INSERT dbo.CustomerPhones
 (CustomerID, Phone1, Phone2, Phone3)
VALUES
 (1,'705-491-1111', '705-491-1110', NULL),
 (2,'613-492-2222', NULL, NULL),
 (3,'416-493-3333', '416-493-3330', '416-493-3339');

 select * from dbo.CustomerPhones

查看數據如下:

DataDataUpivot 實現行轉列

 select * from dbo.CustomerPhones -----數據源
 unpivot 
( 
  Phone FOR Phones IN (Phone1, Phone2, Phone3)
   ##Phone1、Phone2、Phone3這些列的結果轉爲行上的結果,成爲一列,
  ##並且有了新的列名爲Phone
) up

結果如下:

ResultResult

參考文獻:

1.Use SQL Server's UNPIVOT operator to help normalize output

2.SQL之行轉列Pivot用法

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章