笔记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