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

8af4b340e5dedcd6aff80b455a421591.png

前言

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

27dd3a04324310febf5b74f2d681b4e6.png

1 CASE WHEN

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

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

1、简单函数

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

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

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

表score:

a31a44b539f97459dfa637f5627f1a0d.png

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

SQL语句

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

结果

d4727eb4acce8ebf7290a49f5c48f338.png

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

结果

344a4329dea38da41f043c67e4126c2a.png

3、综合使用

CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。

先看第1个场景

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

a31a44b539f97459dfa637f5627f1a0d.png

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;

结果

153e9b8bb4c182d4a9f504de34195ae6.png

再看第2个场景

d95caaa0e6486a5cd17257e87ec367e3.png


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

9f030fcc8d9301d23da625fdf3ba6149.png


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;

结果如下:

604f703e327038a73eb1a0ed03c927ad.png

2 IF

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

IF(expr,result_true,result_false)

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

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

a31a44b539f97459dfa637f5627f1a0d.png


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

d35cb5b4f15bc9ee01b4e596520c86b1.png

3 IFNULL

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

78bb68c483fef5be57bd4e835587f53f.png


因此,我们希望在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;

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

作者:云深i不知处
原文链接:https://blog.csdn.net/mu_wind/article/details/93976316

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/437347.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

记录一次HBase的scan的分页查询

修改前任bug,Hbase查询过于慢了,以至于都查不出来了,看了代码发现使用的Scan只设置了withStartRow、withEndRow、setCaching扫描,拿到全部数据后存入集合再subList进行分页,但是HBase中存在某些数据有几百万条,根本sca…

python需要配置环境变量吗_python需要设置哪些环境变量?我只知道一个PYTHONHOME指向安装目录。(python详细安装教程 path)...

怎么把Python文件夹添加进Path中 “我的电脑”点右键,“属性” “高级”,“环境变量”,“系统变量” 然后,Path添加“c:\python26”之类的。 怎么在Path中添加Python路径 ⒈单击开始,在搜索框输入cmd,然后&…

qt5.3.1+opencv2.4.9编译环境的搭建

到官网下载qt-opensource-windows-x86-mingw482_opengl-5.3.1.exe文件,执行该文件,选择默认安装即可实现QT的安装(安装在C盘的根目录下),该文件封装好了Qt libraries、Qt Creator,其中Qt Creator为3.1.2版本…

Spark2内存调优总结 - 内存划分 与 内存计算 与 调参方式

使用的Spark2以上版本所以只考虑UnifiedMemoryManager动态内存管理,如图: 1. 内存划分 与 内存计算 与 调参方式 1.1 三部分:Spark内存、用户内存、预留内存 预留内存:300MB 固定Spark内存和用户内存比例由参数spark.memory.fra…

java 通过id获取html代码_Maven私服安装配置,java通过私服下载代码,并打包后上传到私服(Nexus)...

Maven私服一般安装Nexus。首先,Nexus下载,访问Nexus官方网址https://www.sonatype.com/download-nexus-repo-oss下载完成后是个压缩包第二步 配置:1)将上一步下载的nexus解压2)端口和监听配置application-port:监听端口applicatio…

Qt下OpenCv中cvGetWindowHandle的使用

昨天因为OpenCv自带的 cvNamedWindow 功能不多,所以想修饰一下,添加几个控件上去,结果获取不到句柄或指针。试了半天无效,于是就准备放弃,打算自己写一个对话框,但是感觉有点麻烦,而且心里不爽&…

一些网站github等无法连接服务器的解决办法

1.打开站长工具 http://tool.chinaz.com/speedtest/ 2.搜索github.com/ 3. 点击总耗时-排序 4. 拿到延迟最低的ip地址20.205.243.166 5.修改本地dns windows:C:\Windows\System32\drivers\etc 修改hosts文件,末尾添加 20.205.243.166 github.com Lin…

【转】异步编程系列(Thread、Task、async/await、ajax等)

序 经过一番努力,我写的异步编程系列也算有头有尾,当然不是说这个系列已经更新完毕,这个头尾只是表示新旧知识点都有简单涉及到,接下去我还会丰富这一系列并且有机会整个小应用(愿景是弄一个开源组件吧,结合…

linux里qt画直线_Qt与Web混合开发(一)简单使用

前言《Qt与Web混合开发》系列文章,主要讨论Qt与Web混合开发相关技术。这类技术存在适用场景,例如:Qt项目使用Web大量现成的组件/方案做功能扩展,Qt项目中性能无关/频繁更新迭代的页面用html单独实现,Qt项目提供Web形式…

ES curator离线安装与部署

1.版本: es:6.5.1 curator:5.8.4 下载地址:https://www.elastic.co/guide/en/elasticsearch/client/curator/current/yum-repository.html#_signing_key_2 2.连接不上网站怎么办? 出现无法访问此网页的话&#xff0…

Qt中qss的使用

Qt支持css样式表,它是网页中用来控制显示的脚本,功能丰富,可以很方便的实现各种显示效果。如果想进一步了解其语法以及使用,可访问www.w3school.com.cn。好在之前在写网站,比较熟悉。 给一个控件添加样式表&#xff0…

【转】1.1异步编程:线程概述及使用

从此图中我们会发现 .NET 与C# 的每个版本发布都是有一个“主题”。即:C#1.0托管代码→C#2.0泛型→C#3.0LINQ→C#4.0动态语言→C#5.0异步编程。现在我为最新版本的“异步编程”主题写系列分享,期待你的查看及点评。 传送门:异步编程系列目录……

安装python3.7.0的步骤_python 3.7.0 安装配置方法图文教程

本文记录了python 3.7.0 安装配置方法,供大家参考,具体内容如下 s1登入python官网 s2下载后缀为exe的可执行文件,并根据自己电脑/主机的系统选择32位还是64位。双击选择“python for windows”() 出现选择下载页面&…

ES:记录curator+nfs进行索引备份、创建快照的一次实践

1. 安装curator工具 下面是我离线安装的过程 https://blog.csdn.net/weixin_43736084/article/details/121775484?spm1001.2014.3001.5501 2.使用fs建立es存储库 我们使用NFS,下面是官网给出的几种仓库类型 2.1 fs建立存储库的注意事项 注意事项,…

Qt : 记录一个编译错误

是信号和槽的使用出现的问题: undefined reference to vtable for ** 解决办法见 http://jingyan.baidu.com/article/47a29f2453d772c0142399ba.html

【转】1.2异步编程:使用线程池管理线程

从此图中我们会发现 .NET 与C# 的每个版本发布都是有一个“主题”。即:C#1.0托管代码→C#2.0泛型→C#3.0LINQ→C#4.0动态语言→C#5.0异步编程。现在我为最新版本的“异步编程”主题写系列分享,期待你的查看及点评。 传送门:异步编程系列目录……

python matplotlib画散点图_python matplotlib库绘制散点图例题解析

假设通过爬虫你获取到了北京2016年3,10月份每天白天的最高气温(分别位于列表a,b),那么此时如何寻找出气温随时间(天)变化的某种规律? a [11,17,16,11,12,11,12,6,6,7,8,9,12,15,14,17,18,21,16…

超好的Git学习网站

超好的Git学习网站 Git很强大,但是学起来太困难了。各种名词很容易搞糊涂,让人丧失兴趣。 那么问题来了,有没有好的教程呢? 偶然间发现这几个网站简直是闲得没事干,做出来这么好的入门教程,比起来纯文字…

Hadoop集群HDFS各节点磁盘使用率不平衡,使用balancer做数据平衡

HDFS上各节点磁盘大小不一致,新增节点 数据平衡前,是非常不均衡的,某些节点已经接近90了 集群的数据平衡已经迫在眉睫,必须要搞一搞了。 1.设置传输速率 我这里是万兆网卡,就先设置100M了 在两台master上分别执行&a…

【转】1.3异步编程:线程同步基元对象

开始《异步编程:同步基元对象(上)》 示例:异步编程:线程同步基元对象.rar 如今的应用程序越来越复杂,我们常常需要多线程技术来提高我们应用程序的响应速度。每个线程都由自己的线程ID,当前指令…