欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL知識點之列轉(zhuǎn)行Unpivot函數(shù)

 更新時間:2019年09月05日 10:55:34   作者:DataFrog  
這篇文章主要給大家介紹了關于SQL知識點之列轉(zhuǎn)行Unpivot函數(shù)的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用SQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

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

先看一個小問題CustomerCustomer

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

UnpivotUnpivot

大家想想看如何實現(xiàn)呢?想下,2分鐘后再看喲

先創(chuàng)建數(shù)據(jù)

 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

查看數(shù)據(jù)如下:

DataDataUpivot 實現(xiàn)行轉(zhuǎn)列

 select * from dbo.CustomerPhones -----數(shù)據(jù)源
 unpivot 
( 
  Phone FOR Phones IN (Phone1, Phone2, Phone3)
   ##Phone1、Phone2、Phone3這些列的結(jié)果轉(zhuǎn)為行上的結(jié)果,成為一列,
  ##并且有了新的列名為Phone
) up

結(jié)果如下:

ResultResult

參考文獻:

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

2.SQL之行轉(zhuǎn)列Pivot用法

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關文章

最新評論