加入收藏 | 设为首页 | 会员中心 | 我要投稿 广州站长网 (https://www.020zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

【195期】MySQL中的条件判断函数 CASE WHEN、IF、IFNULL你

发布时间:2022-10-20 13:32:18 所属栏目:MySql教程 来源:转载
导读: 面试刷图,查缺补漏
>>号外:往期面试题,10篇为一个单位归置到本公众号菜单栏->面试题,有需要的欢迎翻阅
阶段汇总集合:
前言
在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,

面试刷图,查缺补漏

>>号外:往期面试题,10篇为一个单位归置到本公众号菜单栏->面试题,有需要的欢迎翻阅

阶段汇总集合:

前言

在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结CASE WHEN、IF、IFNULL三种函数。

1 CASE WHEN

Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。

CASE WHEN语句分为简单函数和条件表达式。

1、简单函数

CASE?字段?WHEN?预期值?THEN?结果1?ELSE?结果2?END

如果字段值等于预期值,则返回结果1,否则返回结果2。

下面通过一个简单的示例来看一下具体用法。

表score:

MySQL 函数_mysql dateadd函数_mysql的length函数

场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。

SQL语句:

SELECT?name,(CASE?sex?WHEN?0?THEN?'女'?ELSE?'男'?END)?sex?FROM?score

结果:

MySQL 函数_mysql dateadd函数_mysql的length函数

2、条件表达式

CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:

CASE?
?WHEN?condition?THEN?result1??ELSE?result2
END

解释一下,语句中的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

结果:

MySQL 函数_mysql dateadd函数_mysql的length函数

3、综合使用

CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。往期面试题:

先看第1个场景

在下表score(sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。

MySQL 函数_mysql dateadd函数_mysql的length函数

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;

结果:

MySQL 函数_mysql dateadd函数_mysql的length函数

再看第2个场景

MySQL 函数_mysql的length函数_mysql dateadd函数

将上面的score表转换为下面形式:

mysql dateadd函数_mysql的length函数_MySQL 函数

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;

结果如下:

MySQL 函数_mysql dateadd函数_mysql的length函数

2 IF

IF函数也能通过判断条件来返回特定值,它的语法如下:

IF(expr,result_true,result_false)

expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。

往期面试题:

用一个示例演示,还是表score:

MySQL 函数_mysql dateadd函数_mysql的length函数

使用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

在这里插入图片描述3 IFNULL

在Java程序中调用sql语句时,如果返回结果是null,是非常容易引发一些意外情况的。

mysql的length函数_MySQL 函数_mysql dateadd函数

因此MySQL 函数,我们希望在SQL中做一些处理,如果查询结果是null,就转换为特定的值,这就要用到Mysql中IFNULL函数。

首先SQL一般写法是这样的:

SELECT??price?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';12

这时候,需要改写成下面的形式:

--?返回结果:null
SELECT?IFNULL(price,0)?price?FROM?goods?WHERE?name='aaa';

在实际应用中,如果你确定where条件的值一定存在,使用前者就可以了,否则要用后者。

IFNULL函数也可以结合聚合使用,例如:

--?返回结果:0
SELECT?IFNULL(SUM(price),0)?FROM?goods?WHERE?status=3;

其他,AVG、COUNT等用同样方式处理,而且,无论where条件存在不存在,结果都是会返回0的。

END

来源:blog.csdn.net/mu_wind/article/details/93976316

十期推荐

(编辑:广州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!