大家好,欢迎来到IT知识分享网。
大家好,我是宁一。
今天是我们的第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来代替。
下节课我们讲讲大厂面试最常问到的窗口函数。
点击关注,更新课程第一时间通知哦~
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/166158.html