Oracle 在使用pivot时,注意事项

a)         Pivot的时候,实际上也是一次分组,并且可以通过聚簇函数来实现统计

b)         Pivot在取列名的时候,如果别名有汉字,要用双引号括起来,或者不用双引号

c)         如果对应的字段值为非数字或者字母,记得要用单引号引起来,比如下面的’A’

select *

  from (select case

                 when a.score >= 220 and a.score <= 330 then

                  '(220,330)'

                 when a.score >= 630 and a.score <= 710 then

                  '(630,710)'

                 when a.score < 220 then

                  '其他'

                 else

                  '(' || (ceil((a.score - 330) / 20) * 20 + 330) || ',' ||

                  (ceil((a.score - 330) / 20 + 1) * 20 + 330) || ')'

              

               end 分数段,

               b.score

          from SUBJECTREGISTER a

          left join SUBJECTREGISTER b

            on a.candidatesid = b.candidatesid

         WHERE a.testid = '181'

           and a.CAMPUSCODE LIKE '12%'

           AND a.SUBJECTCODE != 'S'

           AND a.SUBJECTCODE != 'F'

           AND (a.SCORE != '0' AND a.SCORE IS NOT NULL and

               b.score IS NOT NULL)

           AND (b.SUBJECTCODE = 'S' or b.SUBJECTCODE = 'F')) pivot(count(SCORE) FOR SCORE IN('A' "A",

                                                                                             'A+' "A+",

                                                                                             'B' "B",

                                                                                             'B+' "B+",

                                                                                             'C' "C",

                                                                                             'C+' "C+",

                                                                                             'D' "D",

                                                                                             'D+' "D+"))

 ORDER BY 分数段

转载于:https://www.cnblogs.com/hobby0524/p/8949407.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值