笔记329 行列转换 2013-7-21
笔记329 行列转换 2013-7-21
1 --行列转换 2013-7-21 2 http://www.cfanz.cn/?c=article&a=read&id=20423 3 USE [pratice] 4 GO 5 CREATE TABLE WEEK_INCOME(WEEK VARCHAR(10),INCOME DECIMAL) 6 7 INSERT INTO WEEK_INCOME 8 SELECT ' 星期一 ', 1000 9 UNION ALL 10 SELECT ' 星期二 ', 2000 11 UNION ALL 12 SELECT ' 星期三 ', 3000 13 UNION ALL 14 SELECT ' 星期四 ', 4000 15 UNION ALL 16 SELECT ' 星期五 ', 5000 17 UNION ALL 18 SELECT ' 星期六 ', 6000 19 UNION ALL 20 SELECT ' 星期日 ', 7000 21 22 --一般我们最经常使用的查询是查询一周中每天或某几天的收入,例如查询周一至周日全部的收入: 23 24 SELECT WEEK,INCOME FROM WEEK_INCOME 25 --得到如下的查询结果集: 26 27 --WEEK INCOME 28 --星期一 1000 29 --星期二 2000 30 --星期三 3000 31 --星期四 4000 32 --星期五 5000 33 --星期六 6000 34 --星期日 7000 35 36 --但是在一些情况下(往往是某些报表中),我们希望在一行中显示周一至周日的收入,这时候查询结果集应该是这样的: 37 38 星期一 星期二 星期三 星期四 星期五 星期六 星期日 39 1000 2000 3000 4000 5000 6000 7000 40 41 --这种情况下,SQL查询语句可以这样写: 42 43 SELECT 44 SUM( CASE WEEK WHEN ' 星期一 ' THEN INCOME END) AS [ 星期一 ] , 45 SUM( CASE WEEK WHEN ' 星期二 ' THEN INCOME END) AS [ 星期二 ] , 46 SUM( CASE WEEK WHEN ' 星期三 ' THEN INCOME END) AS [ 星期三 ] , 47 SUM( CASE WEEK WHEN ' 星期四 ' THEN INCOME END) AS [ 星期四 ] , 48 SUM( CASE WEEK WHEN ' 星期五 ' THEN INCOME END) AS [ 星期五 ] , 49 SUM( CASE WEEK WHEN ' 星期六 ' THEN INCOME END) AS [ 星期六 ] , 50 SUM( CASE WEEK WHEN ' 星期日 ' THEN INCOME END) AS [ 星期日 ] 51 FROM WEEK_INCOME 52 53 --但是,在SQL SERVER 2005中提供了更为简便的方法,这就是"PIVOT"关系运算符。 54 --(相反的“列转行”是UNPIVOT),以下是使用PIVOT实现“行转列”的SQL语句 55 56 SELECT [ 星期一 ] , 57 [ 星期二 ] , 58 [ 星期三 ] , 59 [ 星期四 ] , 60 [ 星期五 ] , 61 [ 星期六 ] , 62 [ 星期日 ] 63 FROM WEEK_INCOME PIVOT 64 ( SUM(INCOME) FOR [week] IN ( [ 星期一 ], [ 星期二 ], [ 星期三 ], [ 星期四 ], [ 星期五 ], 65 [ 星期六 ], [ 星期日 ] ) ) TBL