admin 发表于 2021-11-13 17:11:48

Mysql:条件判断函数-CASE WHEN、IF、IFNULL详解

1 CASE WHENCase when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。CASE WHEN语句分为简单函数和条件表达式。1、简单函数CASE 字段 WHEN 预期值 THEN 结果1 ELSE 结果2 END
如果字段值等于预期值,则返回结果1,否则返回结果2。下面通过一个简单的示例来看一下具体用法。表score:https://pic2.zhimg.com/80/v2-cd9482a9deedafa583488f99ce3522e1_720w.jpg
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。SQL语句:SELECT name,(CASE sex WHEN 0 THEN '女' ELSE '男' END) sex FROM score
结果:https://pic2.zhimg.com/80/v2-5b0394f7b1d3e6c64eafcc3f6e037db5_720w.jpg
2、条件表达式CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:CASE         WHEN condition THEN result1ELSE result2END
解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。SQL:SELECT name,score,(CASE         WHEN score>=90 THEN '优秀'         WHEN score>=80 THEN '良好'         WHEN score>=60 THEN '及格'         ELSE '不及格' END) level FROM score
结果:https://pic4.zhimg.com/80/v2-57bd2ab3485e3d97525e00cd092db7cf_720w.jpg
3、综合使用CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。先看第1个场景在下表score(sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。https://pic2.zhimg.com/80/v2-cd9482a9deedafa583488f99ce3522e1_720w.jpg
SQL:SELECT         SUM(CASE WHEN sex=0 THEN 1 ELSE 0 END) AS 女生人数,        SUM(CASE WHEN sex=1 THEN 1 ELSE 0 END) AS 男生人数,        SUM(CASE WHEN score>=60 AND sex=0 THEN 1 ELSE 0 END) 男生及格人数,        SUM(CASE WHEN score>=60 AND sex=1 THEN 1 ELSE 0 END) 女生及格人数FROM score;
结果:https://pic2.zhimg.com/80/v2-8da071811ef9ea7864e18d1e1d03af5d_720w.jpg
再看第2个场景https://pic2.zhimg.com/80/v2-095197914428a8cad47e6826c5bc7175_720w.jpg
将上面的score表转换为下面形式:https://pic4.zhimg.com/80/v2-81feb05ad0966e5a123818bc30755aa7_720w.jpg
SQL:SELECT         name,        MAX(CASE course WHEN '语文' THEN score ELSE 0 END) AS '语文',        max(CASE course WHEN '数学' THEN score ELSE 0 END) AS '数学',        max(CASE course WHEN '英语' THEN score ELSE 0 END) AS '英语',        AVG(score) AS '平均成绩'FROM score GROUP BY name;
结果如下:https://pic2.zhimg.com/80/v2-5f72c8b70078b45f0bc4885f16247e61_720w.jpg2 IFIF函数也能通过判断条件来返回特定值,它的语法如下:IF(expr,result_true,result_false)
expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。用一个示例演示,还是表score:
https://pic2.zhimg.com/80/v2-cd9482a9deedafa583488f99ce3522e1_720w.jpg
使用IF函数:SELECT name,IF(sex=1,'男','女')sex FROM students;
可以看出,在一些场景中,IF函数和CASE WHEN是有同样效果的,前者相对简单,后者能应对更复杂的判断。另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:SELECT COUNT(IF(sex=1,1,NULL)) 男生人数,COUNT(IF(sex=0,1,NULL))女生人数 FROM students
https://pic4.zhimg.com/80/v2-66abf08db3af27a0c31674c077d6e333_720w.jpg3 IFNULL在Java程序中调用sql语句时,如果返回结果是null,是非常容易引发一些意外情况的。
https://pic4.zhimg.com/80/v2-ef8222cc17650910cc88549e85e5b43b_720w.jpg
因此,我们希望在SQL中做一些处理,如果查询结果是null,就转换为特定的值,这就要用到Mysql中IFNULL函数。首先SQL一般写法是这样的:SELECTprice FROM goods WHERE name='light';
使用IFNULL改写一下:SELECT IFNULL(price,0) price FROM goods WHERE name='light';
但使用IFNULL语句,如果where条件中的name值是不存在的,那么仍将返回null,例如:-- 返回结果:nullSELECT IFNULL(price,0) price FROM goods WHERE name='aaa';
这时候,需要改写成下面的形式:-- 返回结果:0SELECT IFNULL((SELECT price FROM goods WHERE name='aaa'),0) price;
在实际应用中,如果你确定where条件的值一定存在,使用前者就可以了,否则要用后者。IFNULL函数也可以结合聚合使用,例如:-- 返回结果:0SELECT IFNULL(SUM(price),0) FROM goods WHERE status=3;
其他,AVG、COUNT等用同样方式处理,而且,无论where条件存在不存在,结果都是会返回0的。
页: [1]
查看完整版本: Mysql:条件判断函数-CASE WHEN、IF、IFNULL详解