zoukankan      html  css  js  c++  java
  • SQLServer 使用变量动态行转列

    drop table #test
    create table #test
    (
        id int identity(1,1) primary key,
        bizDate varchar(50),
        type varchar(50),
        qty float
    )

    insert into #test
    select '20110501','A',20.5 union all
    select '20110501','B',98 union all
    select '20110501','C',100.5 union all
    select '20110501','A',32 union all
    select '20110501','C',76.8 union all
    select '20110502','B',58 union all
    select '20110502','A',111 union all
    select '20110502','A',51 union all
    select '20110502','A',85 union all
    select '20110502','B',52 union all
    select '20110502','C',43 union all
    select '20110503','A',158 union all
    select '20110503','C',58 union all
    select '20110503','B',28 union all
    select '20110503','B',65 union all
    select '20110503','A',11 union all
    select '20110503','A',25 union all
    select '20110503','C',63

    declare @sql varchar(8000)
    set @sql = 'select type' 
    select @sql = @sql + ' , SUM(CASE WHEN bizDate=''' + bizDate + ''' then qty else 0 end) [' + bizDate + ']'
    from (select distinct bizDate from #test) as a order by bizDate--此行的SQL用于找出不重复的日期,也就是结果集中所有的日期
    set @sql = @sql + ' from #test A group by type'
    print @sql
    exec(@sql)


    --打印出来的完整SQL是:
    select type ,
           SUM(CASE WHEN bizDate='20110501' then qty else 0 end) [20110501] ,
           SUM(CASE WHEN bizDate='20110502' then qty else 0 end) [20110502] ,
           SUM(CASE WHEN bizDate='20110503' then qty else 0 end) [20110503]
           from #test A group by type


          

    /*
    PS. SQLServer里的中括号作用:
     若表名、字段名、列名等与数据库里的关键字有冲突,则可以给该表名或字段名加上"[]"以识区别。
     上面的例子中是以日期作为列名,也可用"[]"标识
    */

  • 相关阅读:
    不用π求坐标夹角大小
    使用LVS实现负载均衡原理及安装配置详解
    从dfs向动态规划过渡
    关于dfs
    [LeetCode] Add Two Numbers
    [LeetCode] Gray Code
    [LeetCode] Single Number
    第四章 深入JSP技术
    蚂蚁破2万亿!身价暴涨2077亿的彭蕾:无论马云的决定是什么,我都让它成为最正确的决定...
    异常场景测试
  • 原文地址:https://www.cnblogs.com/xcxcxcxc/p/5541199.html
Copyright © 2011-2022 走看看