校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 行轉列之SQL SERVER PIVOT與用法詳解

行轉列之SQL SERVER PIVOT與用法詳解

熱門標簽:優質地圖標注 怎樣在地圖上標注路線圖標 智能語音外呼系統選哪家 奧威地圖標注多個地方 京華物流公司地圖標注 外呼系統電銷專用 武漢長沙外呼系統方法和技巧 千呼電銷機器人價格 百度地圖標注不同路線

在數據庫操作中,有些時候我們遇到需要實現“行轉列”的需求,例如一下的表為某店鋪的一周收入情況表:

WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL)

我們先插入一些模擬數據:

INSERT INTO WEEK_INCOME 
SELECT '星期一',1000
UNION ALL
SELECT '星期二',2000
UNION ALL
SELECT '星期三',3000
UNION ALL
SELECT '星期四',4000
UNION ALL
SELECT '星期五',5000
UNION ALL
SELECT '星期六',6000
UNION ALL
SELECT '星期日',7000

一般我們最經常使用的查詢是查詢一周中每天或某幾天的收入,例如查詢周一至周日全部的收入:

SELECT WEEK,INCOME FROM WEEK_INCOME

得到如下的查詢結果集:

WEEK           INCOME
星期一           1000
星期二           2000
星期三           3000
星期四           4000
星期五           5000
星期六           6000
星期日           7000

但是在一些情況下(往往是某些報表中),我們希望在一行中顯示周一至周日的收入,這時候查詢結果集應該是這樣的:

星期一   星期二   星期三   星期四   星期五   星期六   星期日
1000     2000     3000     4000     5000     6000     7000

這種情況下,SQL查詢語句可以這樣寫:

SELECT 
SUM(CASE WEEK WHEN '星期一' THEN INCOME END) AS [星期一],
SUM(CASE WEEK WHEN '星期二' THEN INCOME END) AS [星期二],
SUM(CASE WEEK WHEN '星期三' THEN INCOME END) AS [星期三],
SUM(CASE WEEK WHEN '星期四' THEN INCOME END) AS [星期四],
SUM(CASE WEEK WHEN '星期五' THEN INCOME END) AS [星期五],
SUM(CASE WEEK WHEN '星期六' THEN INCOME END) AS [星期六],
SUM(CASE WEEK WHEN '星期日' THEN INCOME END) AS [星期日]
FROM WEEK_INCOME

但是,在SQL SERVER 2005中提供了更為簡便的方法,這就是"PIVOT"關系運算符。(相反的“列轉行”是UNPIVOT),以下是使用PIVOT實現“行轉列”的SQL語句

SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]
FROM WEEK_INCOME
PIVOT
(
  SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])
)TBL

請參考MSDN中關于PIVOT的用法:

http://technet.microsoft.com/zh-cn/library/ms177410(v=sql.105).aspx

但是MSDN上的描述太過于規范嚴肅,我看了半天還沒弄清楚怎樣使用PIVOT,搞不清楚PIVOT里面的語法的含義。于是又google了很多資料,以及通過上面提到的WEEK_INCOME表例子作了試驗,最終搞清楚了其用法。在網上有篇博文解釋的很好:http://rely1020.blog.ithome.com.tw/post/1606/39111,基本上我要寫的就是參照該博文,再加上自己一點個人理解。

要理解PIVOT語法,就是要清楚微軟為什么這樣設計PIVOT,但我相信是現實需求催生設計思路,所以歸根到底我們還是要弄清楚什么是“行轉列”:

正常情況下的查詢結果是這樣:

星期一           1000
星期二           2000
星期三           3000
星期四           4000
星期五           5000
星期六           6000
星期日           7000

行轉列后是這樣:

星期一   星期二   星期三   星期四   星期五   星期六   星期日
1000    2000    3000    4000    5000    6000    7000

也就是說,行轉列后,原來的某個列的值變做了列名,在這里就是原來WEEK列的值“星期一”,"星期二"..."星期日"邊做了列名,而我們需要做的另一個工作就是計算這些列的值(這里的“計算”其實就是PIVOT里面的聚合函數(sum,avg等))

現在結合注釋來分析一下PIVOT語法(在這之前最好看看我上面提到博文:http://rely1020.blog.ithome.com.tw/post/1606/39111,里面說到的PIVOT語法的三個步驟挺重要):

SELECT [星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日]--這里是PIVOT第三步(選擇行轉列后的結果集的列)這里可以用“*”表示選擇所有列,也可以只選擇某些列(也就是某些天)
FROM WEEK_INCOME --這里是PIVOT第二步驟(準備原始的查詢結果,因為PIVOT是對一個原始的查詢結果集進行轉換操作,所以先查詢一個結果集出來)這里可以是一個select子查詢,但為子查詢時候要指定別名,否則語法錯誤
PIVOT
(
  SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])--這里是PIVOT第一步驟,也是核心的地方,進行行轉列操作。聚合函數SUM表示你需要怎樣處理轉換后的列的值,是總和(sum),還是平均(avg)還是min,max等等。例如如果week_income表中有兩條數據并且其week都是“星期一”,其中一條的income是1000,另一條income是500,那么在這里使用sum,行轉列后“星期一”這個列的值當然是1500了。后面的for [week] in([星期一],[星期二]...)中 for [week]就是說將week列的值分別轉換成一個個列,也就是“以值變列”。但是需要轉換成列的值有可能有很多,我們只想取其中幾個值轉換成列,那么怎樣取呢?就是在in里面了,比如我此刻只想看工作日的收入,在in里面就只寫“星期一”至“星期五”(注意,in里面是原來week列的值,"以值變列")。總的來說,SUM(INCOME) for [week] in([星期一],[星期二],[星期三],[星期四],[星期五],[星期六],[星期日])這句的意思如果直譯出來,就是說:將列[week]值為"星期一","星期二","星期三","星期四","星期五","星期六","星期日"分別轉換成列,這些列的值取income的總和。
)TBL--別名一定要寫

以上是我對PIVOT的理解,我盡所能表達出來。不過話說回來,個人的理解的方式也不同,就如我開始看了很多篇博文,都沒有搞清楚PIVOT用法。結果還是硬的通過例子和別人的博文再加上思考才弄懂了,所以如果各位看了本篇之后仍不能理解,那很正常,配合例子再加上自己思考,慢慢的定能理解。

總結

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

您可能感興趣的文章:
  • Pandas透視表(pivot_table)詳解
  • pandas pivot_table() 按日期分多列數據的方法
  • C#實現Excel動態生成PivotTable
  • SQL基礎教程之行轉列Pivot函數
  • SQL知識點之列轉行Unpivot函數
  • Pandas 重塑(stack)和軸向旋轉(pivot)的實現
  • Python Pivot table透視表使用方法解析

標簽:銅仁 防疫戰設 宿州 天水 威海 益陽 七臺河 來賓

巨人網絡通訊聲明:本文標題《行轉列之SQL SERVER PIVOT與用法詳解》,本文關鍵詞  行轉列,之,SQL,SERVER,PIVOT,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《行轉列之SQL SERVER PIVOT與用法詳解》相關的同類信息!
  • 本頁收集關于行轉列之SQL SERVER PIVOT與用法詳解的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    六月婷婷色综合| 亚洲国产毛片aaaaa无费看 | 日韩高清一级片| 欧美精品99久久久**| 日韩电影在线一区二区| 日韩女优毛片在线| 国内精品久久久久影院一蜜桃| 久久青草欧美一区二区三区| 国产成人av网站| 中文字幕一区二区三区蜜月 | 欧美午夜电影网| 午夜精品成人在线| 精品国产一区久久| 国产精品一区二区三区网站| 18成人在线观看| 欧美日韩国产免费| 国产精品亚洲视频| 亚洲精品午夜久久久| 在线不卡中文字幕播放| 国产一区二区美女| 亚洲欧美一区二区三区极速播放 | 日韩免费视频线观看| 国产精品1024| 一区二区三区免费观看| 日韩一二三区视频| 丁香激情综合五月| 午夜免费久久看| 亚洲国产电影在线观看| 欧美日韩激情一区二区三区| 激情久久久久久久久久久久久久久久| 欧美激情中文字幕一区二区| 欧美日韩一区三区| 国产精品一区免费在线观看| 亚洲午夜在线电影| 中文字幕欧美国产| 欧美一级在线视频| 色呦呦日韩精品| 国产一区二区美女| 爽好多水快深点欧美视频| 国产精品丝袜一区| 日韩精品一区二| 欧美视频一区二区三区在线观看| 国产剧情一区二区| 日韩av成人高清| 一区二区三区精品久久久| 国产日韩三级在线| 日韩午夜激情免费电影| 在线免费精品视频| 成人夜色视频网站在线观看| 麻豆国产欧美一区二区三区| 亚洲午夜精品久久久久久久久| 久久久精品国产免大香伊| 91精品黄色片免费大全| 色综合久久中文字幕| 国产一区二区三区日韩| 日日嗨av一区二区三区四区| 亚洲精品一卡二卡| 中文字幕欧美一| 国产亚洲欧美一区在线观看| 欧美一级高清片| 欧美精品免费视频| 欧美亚洲另类激情小说| 91在线观看美女| 99视频精品全部免费在线| 国产成人免费9x9x人网站视频| 久久疯狂做爰流白浆xx| 日精品一区二区三区| 亚洲mv在线观看| 亚洲国产aⅴ天堂久久| 亚洲免费伊人电影| 日韩美女视频一区| 一区在线观看视频| 国产精品卡一卡二卡三| 国产精品你懂的在线欣赏| 国产欧美在线观看一区| 久久久久久久久久久黄色| 久久色在线视频| 久久久久久影视| 久久青草欧美一区二区三区| 久久色成人在线| www成人在线观看| 久久久久久免费毛片精品| 精品理论电影在线| 久久综合色之久久综合| 欧美激情在线一区二区| 国产精品欧美一区二区三区| 国产精品欧美一级免费| 亚洲少妇中出一区| 亚洲一区二区欧美激情| 午夜久久久久久久久久一区二区| 五月激情六月综合| 日本午夜精品视频在线观看 | 亚洲乱码国产乱码精品精可以看 | 久久精品亚洲精品国产欧美kt∨ | 91福利在线看| 欧美日韩久久一区二区| 欧美一二三区在线| 欧美精品一区二区高清在线观看| 久久亚洲精品小早川怜子| 国产精品―色哟哟| 亚洲伦理在线免费看| 日日夜夜精品免费视频| 韩国欧美一区二区| 91网站最新网址| 91精品国产综合久久精品| 亚洲精品一线二线三线| 国产精品午夜电影| 一区二区三区四区亚洲| 日韩国产欧美一区二区三区| 国产一区二区三区国产| 99久久亚洲一区二区三区青草| 欧美午夜不卡视频| 欧美精品一区二区三区高清aⅴ| 中文字幕亚洲综合久久菠萝蜜| 亚洲成av人片一区二区梦乃| 国产伦精品一区二区三区免费迷 | 国产裸体歌舞团一区二区| 丁香六月久久综合狠狠色| 欧美亚一区二区| 精品免费99久久| 亚洲欧洲精品一区二区精品久久久 | eeuss国产一区二区三区| 欧美在线观看禁18| 精品99一区二区三区| 亚洲一区在线观看免费| 国产福利精品一区| 欧美日韩国产片| 一区在线观看视频| 久久精品国产77777蜜臀| 91猫先生在线| 亚洲精品在线观看视频| 亚洲国产毛片aaaaa无费看 | 日本韩国欧美一区| 2欧美一区二区三区在线观看视频| 亚洲人吸女人奶水| 国模无码大尺度一区二区三区| 91黄色激情网站| 国产精品视频看| 国产在线观看免费一区| 欧美欧美欧美欧美首页| 亚洲免费色视频| 成人午夜激情片| 久久欧美中文字幕| 日韩精品电影在线| 欧美在线免费播放| 亚洲日穴在线视频| 成人精品视频网站| 国产偷国产偷亚洲高清人白洁| 日韩精品亚洲专区| 欧美日韩一区 二区 三区 久久精品| 国产精品久久久久毛片软件| 国产精品一区专区| 精品成人一区二区| 久久99九九99精品| 91精品国产福利在线观看| 亚洲国产欧美日韩另类综合| 色综合天天综合网天天看片| 国产精品热久久久久夜色精品三区| 麻豆精品国产传媒mv男同| 91精品国模一区二区三区| 亚洲超碰97人人做人人爱| 91行情网站电视在线观看高清版| 国产精品美女久久久久久| 国产盗摄女厕一区二区三区| 精品久久久久av影院| 久久66热re国产| 久久久亚洲午夜电影| 国产最新精品免费| 久久久精品黄色| 成人网男人的天堂| 综合欧美亚洲日本| 99国产欧美久久久精品| 综合色中文字幕| 91国内精品野花午夜精品| 亚洲国产人成综合网站| 欧美福利一区二区| 久久99精品久久久久久久久久久久| 日韩欧美国产不卡| 国产一区二区网址| 国产精品狼人久久影院观看方式| 成人污视频在线观看| 亚洲精选视频在线| 欧美精品123区| 国产一区二区伦理| 国产精品久久一卡二卡| 91国产免费看| 免费观看日韩av| 国产日韩欧美一区二区三区综合| av电影一区二区| 亚洲一区二区三区四区不卡| 欧美一级片在线看| 国产福利精品一区| 亚洲精品国产a久久久久久| 欧美精品一二三四| 国内外成人在线视频| 国产精品白丝在线| 欧美高清一级片在线| 国产在线观看一区二区| 亚洲色图视频网| 91精品欧美综合在线观看最新|