零基础自学SQL课程 | CASE函数

大家好,我是宁一。

今天是我们的第23课:CASE函数。

当分类多于两种时,可以用我们上节课讲的IF函数嵌套,也可以用CASE函数,语句可读性会更好。

基本语法:

CASE
    WHEN <条件表达式> THEN <值>
    WHEN <条件表达式> THEN <值>
    WHEN <条件表达式> THEN <值>
    ……
    [ELSE <值>] (可选子句)
END

1、CASE函数

先来看看上节课的实例。

实例:在Students表中,学生编号Sid小于等于3的学生,属于1班;Sid为4到6的学生,属于2班;Sid大于等于7的学生属于3班。最后显示Sname,Sage,所在班级这3列。

我们用IF函数是这样实现的。

SELECT
  Sid,
  Sname,
  IF(Sid<=3,"1班",
    IF(Sid>=7,'3班','2班')
  ) AS "所在班级"
FROM Students

用Case函数可以这样来写:

SELECT
  Sid,
  Sname,
  CASE
    WHEN Sid<=3 THEN "1班"
    WHEN Sid BETWEEN 4 AND 6 THEN "2班"
    WHEN Sid>=7 THEN "3班"
  END AS "所在班级"
FROM Students

要注意,CASE函数一定要用END来结束。WHEN语句之间不需要用逗号隔开。

2、ELSE可选子句

上面的语句如果加上ELSE可选子句,可以这样实现:

SELECT
  Sid,
  Sname,
  CASE
    WHEN Sid<=3 THEN "1班"
    WHEN Sid>=7 THEN "3班"
    ELSE "2班"
  END AS "所在班级"
FROM Students

因为不满足 Sid<=3、Sid>=7,那肯定是4-6之间的数字了,可以直接用ELSE来代替。

下节课我们讲讲大厂面试最常问到的窗口函数。

点击关注,更新课程第一时间通知哦~

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

喵宁一

点赞是最好的赞赏~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值