【Mysql-3】条件判断函数-CASE WHEN、IF、IFNULL详解
前言
在众多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:
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。
SQL语句:
SELECT name,(CASE sex WHEN 0 THEN '女' ELSE '男' END) sex FROM score
结果:
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
结果:
3、综合使用
CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。
先看第1个场景
在下表score
(sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。
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;
结果:
再看第2个场景
将上面的score表转换为下面形式:
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;
结果如下:
2 IF
IF函数也能通过判断条件来返回特定值,它的语法如下:
IF(expr,result_true,result_false)
expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。
用一个示例演示,还是表score:
使用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
,是非常容易引发一些意外情况的。
因此,我们希望在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
,例如:
-- 返回结果:null
SELECT IFNULL(price,0) price FROM goods WHERE name='aaa';
这时候,需要改写成下面的形式:
-- 返回结果:0
SELECT IFNULL((SELECT price FROM goods WHERE name='aaa'),0) price;
在实际应用中,如果你确定where
条件的值一定存在,使用前者就可以了,否则要用后者。
IFNULL
函数也可以结合聚合使用,例如:
-- 返回结果:0
SELECT IFNULL(SUM(price),0) FROM goods WHERE status=3;
其他,AVG
、COUNT
等用同样方式处理,而且,无论where
条件存在不存在,结果都是会返回0的。
- 数据清理的遗留问题处理(r6笔记第87天)
- 一次DB time抖动发现的expdp的bug(r6笔记第86天)
- Python中map函数
- 10g,11g中数据库静默安装中的细小差别(r6笔记第85天)
- SDP(8):文本式数据库-MongoDB-Scala基本操作
- SDP(7):Cassandra- Cassandra-Engine:Streaming
- TensorFlow实现神经网络入门篇
- 27.反射,类加载器,设计模式,jdk新特性
- SDP(6):分布式数据库运算环境- Cassandra-Engine
- 配置dg broker的问题分析及修复(r6笔记第84天)
- SDP(5):ScalikeJDBC- JDBC-Engine:Streaming
- SDP(4):ScalikeJDBC- JDBC-Engine:Updating
- SDP(3):ScalikeJDBC- JDBC-Engine:Fetching
- SDP(2):ScalikeJDBC-Connection Pool Configuration
- MySQL 教程
- MySQL 安装
- MySQL 管理与配置
- MySQL PHP 语法
- MySQL 连接
- MySQL 创建数据库
- MySQL 删除数据库
- MySQL 选择数据库
- MySQL 数据类型
- MySQL 创建数据表
- MySQL 删除数据表
- MySQL 插入数据
- MySQL 查询数据
- MySQL where 子句
- MySQL UPDATE 查询
- MySQL DELETE 语句
- MySQL LIKE 子句
- mysql order by
- Mysql Join的使用
- MySQL NULL 值处理
- MySQL 正则表达式
- MySQL 事务
- MySQL ALTER命令
- MySQL 索引
- MySQL 临时表
- MySQL 复制表
- 查看MySQL 元数据
- MySQL 序列 AUTO_INCREMENT
- MySQL 处理重复数据
- MySQL 及 SQL 注入
- MySQL 导出数据
- MySQL 导入数据
- MYSQL 函数大全
- MySQL Group By 实例讲解
- MySQL Max()函数实例讲解
- mysql count函数实例
- MYSQL UNION和UNION ALL实例
- MySQL IN 用法
- MySQL between and 实例讲解
- 利用JSP内置的Application对象实现的网站引用计数
- JSP导入XML不成功的一个原因
- 生产环境日志清理脚本
- fastadmin插件开发之插件目录
- EasySwoole之定时任务面板
- Gradle构建springBoot项目
- python菜鸟教程 | if elif else 判断
- 图解面试题:人均付费如何分析?
- 面试官拿System.out.println()考了我半个小时?我傻了
- 为何总给外卖打差评?我们来数据分析一下!
- 解决Linux html生成图片中文乱码
- 前端必知必会-BFC案例剖析
- 分析Guava并发工具类Futures
- kafka高可用集群搭建
- ELK7.x日志系统搭建 4. 结合kafka集群完成日志系统