使用SQL行转列函数pivot遇到的问题

背景:对投票的结果按照单位进行汇总统计,数据库中表记录的各个账号对各个选项的投票记录。马上想到一个解决方案,先根据单位和选项进行Group By,然后再行转列得出单位对各个选项的投票情况。

with list as (
    select GroupId,ANSWER,count(1) as num from Vote GROUP BY GroupId,ANSWER
)
select * from list pivot(sum(num) for Answer in (1,2,3,4,5,6)) pvt

PS:数据库中记录的投票选项是1 2 3这样的,果然无意中就留下了一个坑!

1676882-20190613112607264-1895035032.png

一脸懵逼,为啥别人的demo都跑的这么流畅啊!这个报错提示也没什么头绪!没办法还是要硬着头皮上啊!然后网上就各种pivot关键字找找找!哎,突然发现有人在sql中对pivot中列名部分用[]将各个列名包起来了。恍然大悟,这个报错不就是列名或者说字段名不能直接用数字开头!!!赶紧改一下,一切ok!!!

with list as (
    select GroupId,ANSWER,count(1) as num from Vote GROUP BY    GroupId,ANSWER
)
select * from list pivot(sum(num) for Answer in ([1],[2],[3],[4],[5],[6])) pvt

1676882-20190613112624800-1986523650.png

转载于:https://www.cnblogs.com/cplemom/p/11015161.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值