电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

在SQL Server 2005中實現表的行列轉換

瀏覽:13日期:2023-10-30 16:18:16

PIVOT和UNPIVOT關系運算符是SQL Server 2005提供的新增功能,因此,對升級到SQL Server 2005的數據庫使用PIVOT和UNPIVOT時,數據庫的兼容級別必須設置為90(可以使用sp_dbcmptlevel存儲過程設置兼容級別)。在查詢的FROM子句中使用PIVOT和UNPIVOT,可以對一個輸入表值表達式執行某種操作,以獲得另一種形式的表。PIVOT運算符將輸入表的行旋轉為列,并能同時對行執行聚合運算。而UNPIVOT運算符則執行與PIVOT運算符相反的操作,它將輸入表的列旋轉為行。在FROM子句中使用PIVOT和UNPIVOT關系運算符時的語法格式如下:[ FROM { <table_source> } [ ,...n ] ] <table_source> ::= { table_or_view_name [ [ AS ] table_alias ]  <pivoted_table> | <unpivoted_table> }<pivoted_table> ::=table_source PIVOT <pivot_clause> table_alias<pivot_clause> ::=( aggregate_function ( value_column )  FOR pivot_column IN ( <column_list> ) ) <unpivoted_table> ::=table_source UNPIVOT <unpivot_clause> table_alias<unpivot_clause> ::=( value_column FOR pivot_column IN ( <column_list> ) ) <column_list> ::= column_name [ , ... ] table_source PIVOT <pivot_clause>指定對table_source表中的pivot_column列進行透視。table_source可以是一個表、表表達式或子查詢。aggregate_function 系統或用戶定義的聚合函數。注意:不允許使用COUNT(*)系統聚合函數。 value_column PIVOT運算符用于進行計算的值列。與UNPIVOT一起使用時,value_column不能是輸入table_source中的現有列的名稱。FOR pivot_columnPIVOT運算符的透視列。pivot_column必須是可隱式或顯式轉換為nvarchar()的類型。使用UNPIVOT時,pivot_column是從table_source中提取輸出的列名稱,table_source中不能有該名稱的現有列。IN ( column_list )在PIVOT子句中,column_list列出pivot_column中將成為輸出表的列名的值。在UNPIVOT子句中,column_list列出table_source中將被提取到單個pivot_column中的所有列名。table_alias 輸出表的別名。UNPIVOT < unpivot_clause > 指定將輸入表中由column_list指定的多個列的值縮減為名為pivot_column的單個列。常見的可能會用到PIVOT的情形是:需要生成交叉表格報表以匯總數據。交叉表是使用較為廣泛的一種表格式,例如,圖5-4所示的產品銷售表就是一個典型的交叉表,其中的月份和產品種類都可以繼續添加。但是,這種格式在進行數據表存儲的時候卻并不容易管理,要存儲圖5-4這樣的表格數據,數據表通常需要設計為圖5-5這樣的結構。這樣就帶來一個問題,用戶既希望數據容易管理,又希望能夠生成一種能夠容易閱讀的表格數據。好在PIVOT為這種轉換提供了便利。在SQL Server 2005中實現表的行列轉換圖5-4 產品銷售表 圖5-5 數據表結構假設Sales.Orders表中包含有ProductID(產品ID)、OrderMonth(銷售月份)和SubTotal(銷售額)列,并存儲有如表5-2所示的內容。表5-2 Sales.Orders表中的內容ProductID OrderMonth SubTotal 15 100.001 6 100.00 2 5 200.00 26 200.00 2 7 300.00 35400.00 35400.00 執行下面的語句:SELECT ProductID, [5] AS 五月, [6] AS 六月, [7] AS 七月FROM Sales.Orders PIVOT(SUM (Orders.SubTotal)FOR Orders.OrderMonth IN( [5], [6], [7] )) AS pvtORDER BY ProductID;在上面的語句中,Sales.Orders是輸入表,Orders.OrderMonth是透視列(pivot_column),Orders.SubTotal是值列(value_column)。上面的語句將按下面的步驟獲得輸出結果集:a.PIVOT首先按值列之外的列(ProductID和OrderMonth)對輸入表Sales.Orders進行分組匯總,類似執行下面的語句:SELECT ProductID,OrderMonth,SUM (Orders.SubTotal) AS SumSubTotalFROM Sales.OrdersGROUP BY ProductID,OrderMonth;這時候將得到一個如表5-3所示的中間結果集。其中只有ProductID為3的產品由于在5月有2筆銷售記錄,被累加到了一起(值為800)。表5-3 Sales.Orders表經分組匯總后的結果ProductIDOrderMonthSumSubTotal 1 5 100.00 1 6 100.00 2 5 200.00 2 6 200.00 27300.00 35800.00 b.PIVOT根據FOR Orders.OrderMonth IN指定的值5、6、7,首先在結果集中建立名為5、6、7的列,然后從圖5-3所示的中間結果中取出OrderMonth列中取出相符合的值,分別放置到5、6、7的列中。此時得到的結果集的別名為pvt(見語句中AS pvt的指定)。結果集的內容如表5-4所示。表5-4 使用FOR Orders.OrderMonth IN( [5], [6], [7] )后得到的結果集ProductID 5 6 7 1 100.00 100.00 NULL 2 200.00 200.00200.00 3 800.00NULLNULL c.最后根據SELECT ProductID, [5] AS 五月, [6] AS 六月, [7] AS 七月FROM的指定,從別名pvt結果集中檢索數據,并分別將名為5、6、7的列在最終結果集中重新命名為五月、六月、七月。這里需要注意的是FROM的含義,其表示從經PIVOT關系運算符得到的pvt結果集中檢索數據,而不是從Sales.Orders中檢索數據。最終得到的結果集如表5-5所示。表5-5 由表5-2所示的Sales.Orders表將行轉換為列得到的最終結果集ProductID五月六月七月1 100.00 100.00 NULL 2 200.00200.00200.00 3 800.00 NULL NULL UNPIVOT與PIVOT執行幾乎完全相反的操作,將列轉換為行。但是,UNPIVOT并不完全是PIVOT的逆操作,由于在執行PIVOT過程中,數據已經被進行了分組匯總,所以使用UNPIVOT并不會重現原始表值表達式的結果。假設表5-5所示的結果集存儲在一個名為MyPvt的表中,現在需要將列標識符“五月”、“六月”和“七月”轉換到對應于相應產品ID的行值(即返回到表5-3所示的格式)。這意味著必須另外標識兩個列,一個用于存儲月份,一個用于存儲銷售額。為了便于理解,仍舊分別將這兩個列命名為OrderMonth和SumSubTotal。參考下面的語句:CREATE TABLE MyPvt (ProductID int, 五月int, 六月 int, 七月int); --建立MyPvt表GO--將表5-5中所示的值插入到MyPvt表中INSERT INTO MyPvt VALUES (1,100,100,0);INSERT INTO MyPvt VALUES (2,200,200,200);INSERT INTO MyPvt VALUES (3,800,0,0);--執行UNPIVOTSELECT ProductID, OrderMonth, SubTotalFROM  MyPvt UNPIVOT (SubTotal FOR OrderMonth IN (五月, 六月, 七月) )AS unpvt;上面的語句將按下面的步驟獲得輸出結果集:a.首先建立一個臨時結果集的結構,該結構中包含MyPvt表中除IN (五月, 六月, 七月)之外的列,以及SubTotal FOR OrderMonth中指定的值列(SubTotal)和透視列(OrderMonth)。b.將在MyPvt中逐行檢索數據,將表的列名稱(在IN (五月, 六月, 七月)中指定)放入OrderMonth列中,將相應的值放入到SubTotal列中。最后得到的結果集如表5-6所示。表5-6 使用UNPIVOT得到的結果集ProductID OrderMonth SubTotal1五月1001六月100 1七月0 2五月2002六月200 2七月200 3 五月 800 3六月03 七月 0

標簽: Sql Server 數據庫
主站蜘蛛池模板: 减速机电机一体机_带电机减速器一套_德国BOSERL电动机与减速箱生产厂家 | 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 江苏密集柜_电动_手动_移动_盛隆柜业江苏档案密集柜厂家 | 刮板输送机,粉尘加湿搅拌机,螺旋输送机,布袋除尘器 | 京马网,京马建站,网站定制,营销型网站建设,东莞建站,东莞网站建设-首页-京马网 | 协议书_协议合同格式模板范本大全| 保镖公司-私人保镖-深圳保镖公司【环宇兄弟保镖】 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | LINK FASHION 童装·青少年装展 河南卓美创业科技有限公司-河南卓美防雷公司-防雷接地-防雷工程-重庆避雷针-避雷器-防雷检测-避雷带-避雷针-避雷塔、机房防雷、古建筑防雷等-山西防雷公司 | 成人纸尿裤,成人尿不湿,成人护理垫-山东康舜日用品有限公司 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 中宏网-今日新闻-财经新闻| TPU薄膜_TPU薄膜生产厂家_TPU热熔胶膜厂家定制_鑫亘环保科技(深圳)有限公司 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 百方网-百方电气网,电工电气行业专业的B2B电子商务平台 | 郑州墨香品牌设计公司|品牌全案VI设计公司 | 便携式表面粗糙度仪-彩屏硬度计-分体式粗糙度仪-北京凯达科仪科技有限公司 | 液氮罐_液氮容器_自增压液氮罐-北京君方科仪科技发展有限公司 | 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 数码听觉统合训练系统-儿童感觉-早期言语评估与训练系统-北京鑫泰盛世科技发展有限公司 | 山东石英砂过滤器,除氟过滤器「价格低」-淄博胜达水处理 | 欧景装饰设计工程有限公司-无锡欧景装饰官网 | 达利园物流科技集团-| 精密冲床,高速冲床等冲压设备生产商-常州晋志德压力机厂 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 冷油器-冷油器换管改造-连云港灵动列管式冷油器生产厂家 | 京马网,京马建站,网站定制,营销型网站建设,东莞建站,东莞网站建设-首页-京马网 | 合肥卓创建筑装饰,专业办公室装饰、商业空间装修与设计。 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | uv固化机-丝印uv机-工业烤箱-五金蚀刻机-分拣输送机 - 保定市丰辉机械设备制造有限公司 | 烟气在线监测系统_烟气在线监测仪_扬尘检测仪_空气质量监测站「山东风途物联网」 | 仓储笼_金属箱租赁_循环包装_铁网箱_蝴蝶笼租赁_酷龙仓储笼租赁 测试治具|过炉治具|过锡炉治具|工装夹具|测试夹具|允睿自动化设备 | 北京亦庄厂房出租_经开区产业园招商信息平台 | 自动气象站_农业气象站_超声波气象站_防爆气象站-山东万象环境科技有限公司 | 春腾云财 - 为企业提供专业财税咨询、代理记账服务 | 北京成考网-北京成人高考网| 红外光谱仪维修_二手红外光谱仪_红外压片机_红外附件-天津博精仪器 | 中原网视台| 北京网站建设|北京网站开发|北京网站设计|高端做网站公司 | 耐高温电缆厂家-远洋高温电缆 | 北京翻译公司_同传翻译_字幕翻译_合同翻译_英语陪同翻译_影视翻译_翻译盖章-译铭信息 |