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

 

posted @ 2013-08-04 21:57 桦仔 阅读(...) 评论(...)  编辑 收藏