case when 失效,看了这篇文章就明白了

前几天,小明在工作中写sql的时候使用到了case when,发现case when是一个工作中比较常用但是又比较绕的函数,今天特意来给大家分享一下case when 的使用的方法。关于case when的使用情况,总结下来有三种:等值转换、范围转换、列转行操作。1. 等值转换咱们在设计数据库的时候总是会把用户的性别用int存储('0'为女,'1'为男),但是怎么把它转换成汉字显示呢?

SQL语句

注意:最后的 'end' 别丢了,因为小明刚开始使用的时候就有这个毛病,并且一般的case when语句都会比较长,最好添加小括号包起来,这样更容易阅读。

2. 范围转换有的时候会遇到这种情况,按照用户成绩显示优(90分以上)、良(80分-90分)、及格(60分-80分)、未及格(60分以下),这个跟第一个不同的是,他是一个分数的范围,要怎么转换成汉字显示呢?

大家可能觉得很简单,不就是把when那换成条件吗?先打住我们往下看

这是为什么呢?大家想明白了吗?因为如果你在case后写了东西,它会拿后它跟when 对比,我们case 后面写了 score 而when后面写了score>=90 ,然而,'score' 等于 'score>=90'吗? 显然不等于,那该怎么写呢?

3. 列转行操作现在有图1学生成绩数据, 现在要怎么按图2显示出来呢?图1

图2

第一步 先按照科目分开, 符合条件的设置分数,不符合的给置零。

然后再按照名字group by ,对分数求max。

关于case when的用法讲解就到此为止了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值