原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)


最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。

所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。

求一SQL语句。

http://bbs.csdn.net/topics/390496661


  1. create table #tab
  2. (
  3. col1 char(10),
  4. col2 char(10),
  5. item char(10),
  6. num int,
  7. [Date] varchar(10))
  8. insert #tab values('AAA','BBB','A',50,'2013-06-10')
  9. insert #tab values('ABB','BGG','B',30,'2013-06-10')
  10. insert #tab values('AAA','BBB','C',80,'2013-06-13')

我的解法:


  1. create table tab
  2. (
  3. col1 char(10),
  4. col2 char(10),
  5. item char(10),
  6. num int,
  7. [Date] varchar(10)
  8. )
  9. insert tab values('AAA','BBB','A',50,'2013-06-10')
  10. insert tab values('ABB','BGG','B',30,'2013-06-10')
  11. insert tab values('AAA','BBB','C',80,'2013-06-13')
  12. --动态生成sql语句
  13. declare @start_date varchar(10) = '2013-06-01',
  14. @end_date varchar(10) = '2013-06-30';
  15. declare @date varchar(10),
  16. @sql varchar(max) = '',
  17. @sql1 varchar(8000),
  18. @sql2 varchar(8000);
  19. set @date = @start_date;
  20. set @sql1 = 'select case when rownum = 1 then col1 else '''' end as col1,
  21. case when rownum = 1 then col2 else '''' end as col2,
  22. item'
  23. set @sql2 = 'select col1,col2,item,row_number() over(partition by col1,col2
  24. order by item) as rownum'
  25. while @date <= @end_date
  26. begin
  27. set @sql1 = @sql1 + ',v_' + REPLACE( right(@date,5),'-','') +
  28. ' as ''' + CAST(DATEPART(month,@date) as varchar) + '/' +
  29. CAST(DATEPART(day,@date) as varchar) +'''';
  30. set @sql2 = @sql2 + ',SUM(case when date =''' + @date +
  31. ''' then num else 0 end) as v_' +
  32. REPLACE( right(@date,5),'-','')
  33. set @date = CONVERT(varchar(10),dateadd(day,1,@date),120)
  34. end
  35. set @sql = @sql1 + ' from (' +
  36. @sql2 + ' from tab
  37. group by col1,col2,item' +
  38. ') v'
  39. --生产的动态sql语句
  40. select @sql
  41. exec(@sql)

上面由于是动态生成语句,所以不能用局部的临时表,所以建了一个表。

下面是动态生成的sql语句,经过了格式化:


  1. select case when rownum = 1 then col1 else '' end as col1,
  2. case when rownum = 1 then col2 else '' end as col2,
  3. item,
  4. v_0601 as '6/1',v_0602 as '6/2',v_0603 as '6/3',
  5. v_0604 as '6/4',v_0605 as '6/5',
  6. v_0606 as '6/6',v_0607 as '6/7',
  7. v_0608 as '6/8',v_0609 as '6/9',
  8. v_0610 as '6/10',v_0611 as '6/11',
  9. v_0612 as '6/12',v_0613 as '6/13',
  10. v_0614 as '6/14',v_0615 as '6/15',
  11. v_0616 as '6/16',v_0617 as '6/17',
  12. v_0618 as '6/18',v_0619 as '6/19',
  13. v_0620 as '6/20',v_0621 as '6/21',
  14. v_0622 as '6/22',v_0623 as '6/23',
  15. v_0624 as '6/24',v_0625 as '6/25',
  16. v_0626 as '6/26',v_0627 as '6/27',
  17. v_0628 as '6/28',v_0629 as '6/29',
  18. v_0630 as '6/30'
  19. from
  20. (
  21. select col1,col2,item,
  22. row_number() over(partition by col1,col2 order by item) as rownum,
  23. SUM(case when date ='2013-06-01' then num else 0 end) as v_0601,
  24. SUM(case when date ='2013-06-02' then num else 0 end) as v_0602,
  25. SUM(case when date ='2013-06-03' then num else 0 end) as v_0603,
  26. SUM(case when date ='2013-06-04' then num else 0 end) as v_0604,
  27. SUM(case when date ='2013-06-05' then num else 0 end) as v_0605,
  28. SUM(case when date ='2013-06-06' then num else 0 end) as v_0606,
  29. SUM(case when date ='2013-06-07' then num else 0 end) as v_0607,
  30. SUM(case when date ='2013-06-08' then num else 0 end) as v_0608,
  31. SUM(case when date ='2013-06-09' then num else 0 end) as v_0609,
  32. SUM(case when date ='2013-06-10' then num else 0 end) as v_0610,
  33. SUM(case when date ='2013-06-11' then num else 0 end) as v_0611,
  34. SUM(case when date ='2013-06-12' then num else 0 end) as v_0612,
  35. SUM(case when date ='2013-06-13' then num else 0 end) as v_0613,
  36. SUM(case when date ='2013-06-14' then num else 0 end) as v_0614,
  37. SUM(case when date ='2013-06-15' then num else 0 end) as v_0615,
  38. SUM(case when date ='2013-06-16' then num else 0 end) as v_0616,
  39. SUM(case when date ='2013-06-17' then num else 0 end) as v_0617,
  40. SUM(case when date ='2013-06-18' then num else 0 end) as v_0618,
  41. SUM(case when date ='2013-06-19' then num else 0 end) as v_0619,
  42. SUM(case when date ='2013-06-20' then num else 0 end) as v_0620,
  43. SUM(case when date ='2013-06-21' then num else 0 end) as v_0621,
  44. SUM(case when date ='2013-06-22' then num else 0 end) as v_0622,
  45. SUM(case when date ='2013-06-23' then num else 0 end) as v_0623,
  46. SUM(case when date ='2013-06-24' then num else 0 end) as v_0624,
  47. SUM(case when date ='2013-06-25' then num else 0 end) as v_0625,
  48. SUM(case when date ='2013-06-26' then num else 0 end) as v_0626,
  49. SUM(case when date ='2013-06-27' then num else 0 end) as v_0627,
  50. SUM(case when date ='2013-06-28' then num else 0 end) as v_0628,
  51. SUM(case when date ='2013-06-29' then num else 0 end) as v_0629,
  52. SUM(case when date ='2013-06-30' then num else 0 end) as v_0630
  53. from tab
  54. group by col1,col2,item
  55. ) v

发布了416 篇原创文章 · 获赞 135 · 访问量 95万+

在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)的更多相关文章

  1. 在论坛中出现的比较难的sql问题:29(row_number函数 组内某列的值连续出现3次标记出来)

    原文:在论坛中出现的比较难的sql问题:29(row_number函数 组内某列的值连续出现3次标记出来) 在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘 ...

  2. 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)

    原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  3. 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)

    原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...

  4. 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)

    原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...

  5. 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)

    原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  6. 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)

    原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

  7. 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)

    原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...

  8. 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)

    原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...

  9. 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)

    原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.

随机推荐

  1. Acunetix Web Vulnerability Scanner abbr. AWVS

    awvs 中文手册详细版 - 木讷 - 博客园https://www.cnblogs.com/iamver/p/7124718.html Download Acunetix Trialhttps:// ...

  2. openresty开发系列10--openresty的简单介绍及安装

    openresty开发系列10--openresty的简单介绍及安装 一.Nginx优点 十几年前,互联网没有这么火,软件外包开发,信息化建设,帮助企业做无纸化办公,收银系统,工厂erp,c/s架构偏 ...

  3. 【转】asp获取【微信公众平台】Access Token的源代码下载

    在做微信开发时候,经常要用到Access Token,但是官网提供的都是基于php写的,我用asp写了,有需要可以直接复制去用,模板消息,jdk上传图片,客服消息等全需要这个:'获取 access_t ...

  4. Java中使用Socket连接判断Inputstream结束,java tcp socket服务端,python tcp socket客户端

    最近在试着用java写一个socket的服务器,用python写一个socket的客户端来完成二者之间的通信,但是发现存在一个问题,服务器方面就卡在读取inputsream的地方不动了,导致后面的代码 ...

  5. 深入学习c++--多线程编程(二)【当线程间需要共享非const资源】

    1. 遇到的问题 #include <iostream> #include <thread> #include <chrono> #include <futu ...

  6. Swift 4.0 + Ipad开发项目中值得注意知识点

    1.注意Xib的约束和代码的约束,注意适配问题: 2.设置view的frame可以使用view.frame.maxX实现布局: 3.UIStackView在xib中的使用,可以很好的实现约束,布局和屏 ...

  7. jquery weui 图片浏览器Photo Browser

    jquery weui 图片浏览器Photo Browser 如何使用? 对应组件地址:http://jqweui.com/extends#swiper 先说说业务场景:类似朋友圈这样的布局效果,点击 ...

  8. MySQL之忘记root重置方法

    参考:https://help.aliyun.com/knowledge_detail/42520.html MySQL忘记了root登录密码需要重置 1,修改配置文件 一般配置文件路径为/etc/m ...

  9. 08点睛Spring MVC4.1-Spring MVC的配置(含自定义HttpMessageConverter)

    8.1 配置 Spring MVC的配置是通过继承WebMvcConfigurerAdapter类并重载其方法实现的; 前几个教程已做了得配置包括 01点睛Spring MVC 4.1-搭建环境 配置 ...

  10. 13点睛Spring4.1-Spring EL

    13.1 Spring EL Spring EL-Spring表达式语言,支持在xml和注解中使用表达式,类似jsp的EL表达式语言; 本教程关注于在注解中使用Spring EL; Spring EL ...