在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。
所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。
求一SQL语句。
http://bbs.csdn.net/topics/390496661
-
create table #tab
-
(
-
col1 char(10),
-
col2 char(10),
-
item char(10),
-
num int,
-
[Date] varchar(10))
-
insert #tab values('AAA','BBB','A',50,'2013-06-10')
-
insert #tab values('ABB','BGG','B',30,'2013-06-10')
-
insert #tab values('AAA','BBB','C',80,'2013-06-13')
我的解法:
-
create table tab
-
(
-
col1 char(10),
-
col2 char(10),
-
item char(10),
-
num int,
-
[Date] varchar(10)
-
)
-
-
insert tab values('AAA','BBB','A',50,'2013-06-10')
-
insert tab values('ABB','BGG','B',30,'2013-06-10')
-
insert tab values('AAA','BBB','C',80,'2013-06-13')
-
-
-
-
-
--动态生成sql语句
-
declare @start_date varchar(10) = '2013-06-01',
-
@end_date varchar(10) = '2013-06-30';
-
-
declare @date varchar(10),
-
@sql varchar(max) = '',
-
@sql1 varchar(8000),
-
@sql2 varchar(8000);
-
-
set @date = @start_date;
-
-
set @sql1 = 'select case when rownum = 1 then col1 else '''' end as col1,
-
case when rownum = 1 then col2 else '''' end as col2,
-
item'
-
-
set @sql2 = 'select col1,col2,item,row_number() over(partition by col1,col2
-
order by item) as rownum'
-
-
-
while @date <= @end_date
-
begin
-
set @sql1 = @sql1 + ',v_' + REPLACE( right(@date,5),'-','') +
-
' as ''' + CAST(DATEPART(month,@date) as varchar) + '/' +
-
CAST(DATEPART(day,@date) as varchar) +'''';
-
set @sql2 = @sql2 + ',SUM(case when date =''' + @date +
-
''' then num else 0 end) as v_' +
-
REPLACE( right(@date,5),'-','')
-
-
set @date = CONVERT(varchar(10),dateadd(day,1,@date),120)
-
end
-
-
-
set @sql = @sql1 + ' from (' +
-
@sql2 + ' from tab
-
group by col1,col2,item' +
-
') v'
-
-
--生产的动态sql语句
-
select @sql
-
-
-
exec(@sql)
上面由于是动态生成语句,所以不能用局部的临时表,所以建了一个表。
下面是动态生成的sql语句,经过了格式化:
-
select case when rownum = 1 then col1 else '' end as col1,
-
case when rownum = 1 then col2 else '' end as col2,
-
item,
-
-
v_0601 as '6/1',v_0602 as '6/2',v_0603 as '6/3',
-
v_0604 as '6/4',v_0605 as '6/5',
-
v_0606 as '6/6',v_0607 as '6/7',
-
v_0608 as '6/8',v_0609 as '6/9',
-
v_0610 as '6/10',v_0611 as '6/11',
-
v_0612 as '6/12',v_0613 as '6/13',
-
v_0614 as '6/14',v_0615 as '6/15',
-
v_0616 as '6/16',v_0617 as '6/17',
-
v_0618 as '6/18',v_0619 as '6/19',
-
v_0620 as '6/20',v_0621 as '6/21',
-
v_0622 as '6/22',v_0623 as '6/23',
-
v_0624 as '6/24',v_0625 as '6/25',
-
v_0626 as '6/26',v_0627 as '6/27',
-
v_0628 as '6/28',v_0629 as '6/29',
-
v_0630 as '6/30'
-
from
-
(
-
select col1,col2,item,
-
-
row_number() over(partition by col1,col2 order by item) as rownum,
-
-
SUM(case when date ='2013-06-01' then num else 0 end) as v_0601,
-
SUM(case when date ='2013-06-02' then num else 0 end) as v_0602,
-
SUM(case when date ='2013-06-03' then num else 0 end) as v_0603,
-
SUM(case when date ='2013-06-04' then num else 0 end) as v_0604,
-
SUM(case when date ='2013-06-05' then num else 0 end) as v_0605,
-
SUM(case when date ='2013-06-06' then num else 0 end) as v_0606,
-
SUM(case when date ='2013-06-07' then num else 0 end) as v_0607,
-
SUM(case when date ='2013-06-08' then num else 0 end) as v_0608,
-
SUM(case when date ='2013-06-09' then num else 0 end) as v_0609,
-
SUM(case when date ='2013-06-10' then num else 0 end) as v_0610,
-
SUM(case when date ='2013-06-11' then num else 0 end) as v_0611,
-
SUM(case when date ='2013-06-12' then num else 0 end) as v_0612,
-
SUM(case when date ='2013-06-13' then num else 0 end) as v_0613,
-
SUM(case when date ='2013-06-14' then num else 0 end) as v_0614,
-
SUM(case when date ='2013-06-15' then num else 0 end) as v_0615,
-
SUM(case when date ='2013-06-16' then num else 0 end) as v_0616,
-
SUM(case when date ='2013-06-17' then num else 0 end) as v_0617,
-
SUM(case when date ='2013-06-18' then num else 0 end) as v_0618,
-
SUM(case when date ='2013-06-19' then num else 0 end) as v_0619,
-
SUM(case when date ='2013-06-20' then num else 0 end) as v_0620,
-
SUM(case when date ='2013-06-21' then num else 0 end) as v_0621,
-
SUM(case when date ='2013-06-22' then num else 0 end) as v_0622,
-
SUM(case when date ='2013-06-23' then num else 0 end) as v_0623,
-
SUM(case when date ='2013-06-24' then num else 0 end) as v_0624,
-
SUM(case when date ='2013-06-25' then num else 0 end) as v_0625,
-
SUM(case when date ='2013-06-26' then num else 0 end) as v_0626,
-
SUM(case when date ='2013-06-27' then num else 0 end) as v_0627,
-
SUM(case when date ='2013-06-28' then num else 0 end) as v_0628,
-
SUM(case when date ='2013-06-29' then num else 0 end) as v_0629,
-
SUM(case when date ='2013-06-30' then num else 0 end) as v_0630
-
from tab
-
group by col1,col2,item
-
) v
在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)的更多相关文章
- 在论坛中出现的比较难的sql问题:29(row_number函数 组内某列的值连续出现3次标记出来)
原文:在论坛中出现的比较难的sql问题:29(row_number函数 组内某列的值连续出现3次标记出来) 在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘 ...
- 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)
原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)
原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...
- 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)
原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...
- 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)
原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)
原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)
原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)
原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...
- 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)
原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
随机推荐
- 多层If语句 和 表格驱动 的对比
网文提到表格驱动,总喜欢拿一层if做例子,然而这样未免也太简单. 下文是三层缩进的if和表驱动比较,大家可自行判断优劣. 业务是这样的,某景点分旺季票价和淡季票价,淡季票为旺季的一半,15岁以下孩子再 ...
- Python5种代码维护工具
原文地址:https://cloud.tencent.com/developer/article/1365969 随着软件项目进入“维护模式”,对可读性和编码标准的要求很容易落空(甚至从一开始就没有建 ...
- Flutter -------- dio网络请求
dio是Flutter中文网开源的一个强大的Dart Http请求库,支持Restful API.FormData.拦截器.请求取消.Cookie管理.文件上传/下载.超时等... 1.添加依赖# d ...
- yii2 下的redis常用命令集合
<?php \Yii::$app->redis->set('user','aaa'); \Yii::$app->redis->set('user2','bbb'); \Y ...
- pytorch torch.nn 实现上采样——nn.Upsample
Vision layers 1)Upsample CLASS torch.nn.Upsample(size=None, scale_factor=None, mode='nearest', align ...
- Microsoft VBScript 运行时错误 错误 800a005e 无效使用 Null: Replace
查看数据库 表的字段里面是否有空的字段. where 字段名 is null
- AndroidKiller简单使用:修改应用名称
修改apk名称 软件清晰地展示了美柚的信息.(是反编译的不错选择) 切换到工程管理器,可以查看反编译的资源和smail代码等. 接下来,查看smali代码,找到你需要查看的文件,点击下图的这个图标 看 ...
- Spring cloud微服务安全实战-5-8实现基于session的SSO(认证服务器的session有效期)
认证服务器 session的有效期. 也就是认证服务器上的session的有效期 生成环境下,认证服务器一定是一个集群.集群.那么session一定是要在所有的服务器之间进行共享的.最简单的方式是用S ...
- linux传输文件lrzsz
linux传输文件
- NETTY keeplive 参数,心跳检测
当设置为true的时候,TCP会实现监控连接是否有效,当连接处于空闲状态的时候,超过了2个小时,本地的TCP实现会发送一个数据包给远程的 socket,如果远程没有发回响应,TCP会持续尝试11分钟, ...