sql server 生成透视表

---恢复内容开始---

实例:

empidcustidqty
2A52
3A20
1B20
2B27
1C34
3C22
3D30

 

要求转换后的透视图如下:

empidABCD
1NULL2034NULL
25227NULLNULL
320NULL2230

1.标准sql 进行透视转换

  select empid,

    sum(case when custid ='A' then qty End) AS A,

    sum(case when custid ='B' then qty End) AS B,

    sum(case when custid ='C' then qty End) AS C,

    sum(case when custid ='D' then qty End) AS D

  from dbo.Orders

  Group by empid;

2. 使用T-sql 特定的Pivot运算符

  select empid, A, B, C, D

  From (Select empid, custid, qty

      from dbo.Orders)AS D

     Pivot(Sum(qty) for custid, A, B, C, D)) As P;

3. 拼接sql 语句

    declare @str varchar(200);   

    set @str = 'select [empid], '

    select @str = @str + 'sum(case custid when '+quotename(custid,'''')+' then qty else 0 end) as '+quotename(custid)+','  from dbo.Orders group by custid

    select @str = left(@str, len(@str)-1)

    select @str = @str + '  from dbo.Orders group by [empid]'

    exec(@str)

参考文献:

  1.  Microsoft sql server 2008技术内幕: T-sql语言基础

  2.  http://www.cnblogs.com/shangfc/archive/2010/09/14/1826307.html

转载于:https://www.cnblogs.com/charlsZhang/p/3387321.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值