点击上方“Java面试题精选”,关注公众号

面试刷图,查缺补漏

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

阶段汇总集合:001期~180期汇总,方便阅读(增加设计模式)

前言

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

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

结果:3、综合使用

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

先看第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。

往期面试题:001期~180期汇总

用一个示例演示,还是表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,例如:

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

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

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

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

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

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

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

END

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

十期推荐

【181期】HashMap 面试二十一问!

【182期】SpringCloud常见面试题(2020最新版)

【183期】面试官:线上服务平均响应时间太长,怎么排查?

【184期】SQL数据库面试题以及答案(50例题)

【185期】面试官:你能说说 Synchronized实现对象锁的两种方式以及它的原理吗?

【186期】一口气说出 Synchronized 同步方法的八种使用场景

【187期】出现几率比较大的Redis面试题(含答案)

【188期】面试官:delete、truncate、drop的区别有哪些,该如何选择

【189期】delete后加 limit是个好习惯么

【190期】MQ消息中间件,面试能问写什么?

与其在网上拼命找题? 不如马上关注我们~

.net一个函数要用另一个函数的值_【195期】MySQL中的条件判断函数 CASE WHEN、IF、IFNULL你会用吗?...相关推荐

  1. MySQL中的条件判断函数 CASE WHEN、IF、IFNULL你会用吗?

    前言 参考文章:https://mp.weixin.qq.com/s?__biz=MzIyNDU2ODA4OQ==&mid=2247486529&idx=1&sn=6d5cd7 ...

  2. 中if判断中文_当Excel表格中的条件判断超过8个,用IF函数不容易实现怎么办?...

    点击上方蓝字  免费关注 置顶公众号或设为星标,否则可能收不到文章 个人微信号 | (ID:LiRuiExcel520) 微信服务号 | 跟李锐学Excel(ID:LiRuiExcel) 微信公众号  ...

  3. mysql判断条件用法,MySQL数据库讲解条件判断函数 MySQL数据库使用教程

    函数: (1)IF(expr,v1,v2)函数 (2)IFNULL(v1,v2)函数 (3)CASE函数 (相关免费学习推荐:mysql视频教程) (1)if(expr,v1,v2)函数 在if(ex ...

  4. .net一个函数要用另一个函数的值_Mysql:条件判断函数-CASE WHEN、IF、IFNULL详解

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

  5. MySQL中常见的单行函数(下)

    MySQL中常见的单行函数(下) 一.转换函数 Date_format(date,format) 将日期转换成字符串(类似Oracle中的to_char()) Str_to_date(str,fo ...

  6. mysql 条件 函数_mysql 函数 时间函数,数学函数,字符串函数,条件判断函数

    =========================================== mysql 相关函数 ============================================= ...

  7. Python 数据分析三剑客之 NumPy(五):数学 / 算术 / 统计 / 排序 / 条件 / 判断函数合集

    CSDN 课程推荐:<Python 数据分析与挖掘>,讲师刘顺祥,浙江工商大学统计学硕士,数据分析师,曾担任唯品会大数据部担任数据分析师一职,负责支付环节的数据分析业务.曾与联想.亨氏.网 ...

  8. mysql中的内置函数

    mysql内置函数列表可以从mysql官方文档查询,这里仅分类简单介绍一些可能会用到的函数. 1 数学函数 abs(x) pi() mod(x,y) sqrt(x) ceil(x)或者ceiling( ...

  9. mysql 排名_学会在MySQL中实现Rank高级排名函数,所有取前几名问题全部解决.

    MySQL中没有Rank排名函数,当我们需要查询排名时,只能使用MySQL数据库中的基本查询语句来查询普通排名.尽管如此,可不要小瞧基础而简单的查询语句,我们可以利用其来达到Rank函数一样的高级排名 ...

最新文章

  1. keepalived 多实例
  2. ubunto用户切换
  3. 【转】ADO.Net之SqlConnection、 Sqlcommand的应用学习心得(思维导图,知识解析,案例分析)
  4. Snipaste的安装及快捷键的设置
  5. 弱电工程集成商_弱电工程楼宇自控系统基础知识培训资料
  6. Zabbix实战-简易教程--订阅类
  7. PyTorch学习记录-1PyTorch安装
  8. 确认过眼神,你是要来百度AI开发者实战营深圳站的人
  9. iOS URL Scheme 劫持-在未越狱的 iPhone 6上盗取支付宝和微信支付的帐号密码
  10. 4linux--------操作系统介绍 - 项目前导必备------全栈式开发40
  11. JavaScript 技术篇 - js读取Excel文档里的内容实例演示,js如何读取excel指定单元格的内容,js将excel的内容转化为json字符串方法
  12. HttpServletRequest获取中文参数乱码问题
  13. JVM(四).Class 文件结构(附字节码完整解析)
  14. HR人力资源管理系统面试时怎么介绍的思路
  15. 永远不要使用 Boolean 对象
  16. 微信小程序使用阿里云物联网API开发物联网应用
  17. EventBus Vuex?
  18. 三、实战---爬取百度指定词条所对应的结果页面(一个简单的页面采集器)
  19. conda create -n scrapy_spader python=3.6 报错CondaHTTPError
  20. 【操作系统】第五章——虚拟内存技术

热门文章

  1. 暑假旅游小高峰,旅游行业都在烧钱赚人气
  2. ie-css3.htc参数无效,ie-css3.htc怎么用?
  3. 10代cpu装win7_11代CPU共26款型号全曝光:10核心确定没了
  4. Python编程4道练习题
  5. Python操作JSON和CSV
  6. python中使用for循环,while循环,一条命令打印99乘法表
  7. 计算机高级语言程序Access,[计算机软件及应用]Access的编程语言VBA.ppt
  8. html提供的常用的页面交换元素有哪些,一些常用网页制作代码收集汇总
  9. php 大数运算类,PHP采用超长(超大)数字运算防止数字以科学计数法显示的方法
  10. linux 信号 sigaction(是signal的扩展,在多线程应用中替代了signal)(除了信号值信息外,还可以附加数值信息(以及指针:不可跨进程):sigqueue()函数)