top

笔记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 @   桦仔  阅读(325)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
点击右上角即可分享
微信分享提示