oracle pivot非空处理,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 分数段

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值