关键词:
- 备战2022春招或暑期实习,本专栏会持续输出MySQL系列文章,祝大家每天进步亿点点!文末私信作者,我们一起去大厂。
- 本篇总结的是 《MySQL之流程函数》,后续会每日更新~
- 关于《Redis入门到精通》、《并发编程》、《Java全面入门》、《鸿蒙开发》等知识点可以参考我的往期博客
- 相信自己,越活越坚强,活着就该逢山开路,遇水架桥!生活,你给我压力,我还你奇迹!
目录
一、简介
流程函数在MySQL中使用的不是非常频繁,但是涉及到条件筛选等特殊场景时,使用流程函数能带来非常大的便捷,提高语句的效率。
二、流程函数
常见的流程函数有四个,如下表所示:
函数 | 功能 |
---|---|
if(value, t, f) | 如果value为true,则返回t,否则返回f |
ifnull(value1, value2) | 如果value1不为null,返回value1,否则返回value2 |
case when [val1] then [res1] … else [default] end | 如果val1为true,则返回res1,否则返回default默认值 |
case [expr] when [val1] then [res1] … else [default] end | 如果expr的值等于val1,则返回res1,否则返回default默认值 |
首先来看一下这四个流程函数的基本使用方法:
A. if
select if(true, 'Ok', 'Error');
B. ifnull
select ifnull('', 'Default');
此处需要注意,''空串并不等于null,因此返回就是''
select ifnull(null, 'Default');
这种情况才是null,返回Default默认值
为了方便测试,需先创建一张测试表,表结构和数据如下所示:
create table tb_employ
(
id int not null comment '员工ID',
name varchar(10) null comment '员工姓名',
work_address varchar(20) null comment '工作地点',
entry_date date null comment '入职日期',
constraint tb_employ_pk
primary key (id)
)comment '职员表';
insert into tb_employ (id, name, work_address, entry_date)
values (1, '李子捌', '深圳', '2019-07-01'),
(2, '李子柒', '成都', '2015-06-21'),
(3, '梁某人', '北京', '2022-01-22');
C. case when [val1] then [res1] … else [default] end
需求:查询职员表中,各职员所处城市级别,北京深圳为一线城市,其余为二线城市
select name,
(case when '北京' then '一线城市' when '深圳' then '一线城市' else '二线城市' end) as '城市级别'
from tb_employ;
为了方便测试,需先创建一张测试表,表结构和数据如下所示:
-- auto-generated definition
create table tb_score
(
id int not null comment '用户ID' primary key,
name varchar(15) default '0' null comment '姓名',
chinese int default 0 null comment '语文',
math int default 0 null comment '数学',
english int default 0 null comment '英语'
) comment '成绩表';
insert into tb_score (id, name, chinese, math, english)
values (1, '李子捌', 88, 100, 79),
(2, '梁某人', 95, 94, 100),
(3, '李子柒', 92, 88, 91);
D. case [expr] when [val1] then [res1] … else [default] end
需求:成绩大于等于90分为优秀,大于等于80为良好,其余为及格
select name,
(case when chinese >= 90 then '优秀' when chinese >= 80 then '良好' else '及格' end) as '语文',
(case when math >= 90 then '优秀' when math >= 80 then '良好' else '及格' end) as '数学',
(case when english >= 90 then '优秀' when english >= 80 then '良好' else '及格' end) as '英语'
from tb_score;
mysql之流程函数(代码片段)
...末私信作者,我们一起去大厂。本篇总结的是《MySQL之流程函数》,后续会每日更新~关于《Redis入门到精通》、《并发编程》、《Java全面入门》、《鸿蒙开发》等知识点可以参考我的往期博客相信自己,越活越坚强... 查看详情
python之流程控制(代码片段)
Python之流程控制if语句条件判断语句ifa==b:pass#满足条件再执行ifa==b:passelse:pass#满足条件执行第一种语句,不满足条件则执行第二种语句ifa==b:#条件1pass#语句1elifa>b:#条件2pass#语句2else:pass#语句3如果满足条件1,则执行语句1,语句2... 查看详情
java基础之流程语句(代码片段)
JAVA流程语句有几下几种:一、if语句:1.if语句:如果满足条件语句,则执行执行语句; if(条件语句) 执行语句; ....; 2.if....else语句:如果满足判断语句,则执行执行语句1,否则执行执行语句2;... 查看详情
mysql之流程控制语句
参考技术AMYSQL的流程控制语句也只能用于存储过程,主要有3类:跳转语句ITERATE:只能用在循环语句内,表示重新开始循环。LEAVE:可以用在循环语句内,或者以BEGIN和END包裹起来的程序体内,表示跳出循环或跳出程序体的操作。... 查看详情
flowable系列之流程变量(代码片段)
流程变量 流程实例按步骤执行时,需要使用一些数据。在Flowable中,这些数据称作变量(variable),并会存储在数据库中。变量可以用在表达式中(例如在排他网关中用于选择正确的出口路径),也可以在... 查看详情
第八篇flowable之流程变量(代码片段)
流程变量 流程实例按步骤执行时,需要使用一些数据。在Flowable中,这些数据称作变量(variable),并会存储在数据库中。变量可以用在表达式中(例如在排他网关中用于选择正确的出口路径),也可以在... 查看详情
go语言基础之流程控制(代码片段)
流程控制是每种编程语言控制逻辑走向和执行次序的重要部分,流程控制可以说是一门语言的“经脉”。Go语言中最常用的流程控制有if和for,而switch和goto主要是为了简化代码、降低重复代码而生的结构,属于扩展类的流程控制... 查看详情
细说webpack之流程篇(代码片段)
引言目前,几乎所有业务的开发构建都会用到webpack。的确,作为模块加载和打包神器,只需配置几个文件,加载各种loader就可以享受无痛流程化开发。但对于webpack这样一个复杂度较高的插件集合,它的整体流... 查看详情
javascript基础之流程控制语句
第三部分:流程控制语句JavaScript代码是书写位置:JavaScript代码应该写在<scripttype=”text/javascript”></script>这一对标记中。或者作为外部引用<scriptsrc="JavaScript代码路径"></script>JavaScript的每一句代码请用分号作为... 查看详情
存储过程之流程控制语句
阅读目录:通过条件、循环语句,对处理程序进行流程控制条件控制 IF条件:条件为真,执行 CASE条件:匹配到,执行循环控制 WHILE循环:先判断后执行 REPEAT循环:先执行后判断 LOOP循环... 查看详情
1.golang开发之流程控制(代码片段)
Golang开发之流程控制1.条件判断(if)Go语言if条件判断格式如下:if表达式1分支1elseif表达式2分支2else分支3Go规定与if匹配的左括号“”必须与if和表达式放在同一行,如果尝试将“”放在其它位置,将会触发编译错误,... 查看详情
java基础之流程控制
一、顺序结构 顺序结构的程序语句只能被执行一次。如果您想要同样的操作执行多次,,就需要使用循环结构。 if-else-if语句语法: if(条件){ 当条件为true时,执行大括号内... 查看详情
阿花宝宝java基础笔记之流程控制
1.语法:if(条件1){ //代码1 }elseif(条件2){ //代码块2& 查看详情
django之流程
关键点路由视图模板orm中间件 查看详情
3.go语言基础之流程控制(代码片段)
1.ifelse(分支结构)1.1if判断基本语法if条件判断的格式如下:if表达式1分支1elseif表达式2分支2else分支3Go语言规定与if匹配的左括号必须与if和表达式放在同一行,放在其他位置会触发编译错误。同理,与else匹配的也必须与else写在同... 查看详情
shell脚本之流程控制
shell脚本之流程控制shell脚本之流程控制条件语句条件判断循环语句for,while,untilfor循环while循环until循环循环控制语句continue循环控制语句break循环控制shift命令创建无限循环while的特殊用法for的特殊用法select循环与菜单s... 查看详情
java程序猿之流程控制与数组
分支语句 if括号里的只能是一个逻辑表达式,即这个表达式返回的值只能是true或false。 代码块用花括号括起来,一个代码块通常被当成一个整体来执行(除非遇到return、break、continue等关键字,或者遇到异常)。 ... 查看详情
java学习之流程控制语句(选择结构)
流程控制语句1选择结构ifif语句有三种语法格式,每一种格式都有它自身的特点。1.1if语句if语句是指如果满足某种条件,就进行某种处理。在Java中,if语句的具体语法格式如下:if(条件语句){ 执行语句; ... 查看详情