mysql之流程函数(代码片段)

李子捌 李子捌     2022-12-03     792

关键词:

  •   备战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全面入门》、《鸿蒙开发》等知识点可以参考我的往期博客相信自己,越活越坚强&#x... 查看详情

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(条件语句){   执行语句;  ... 查看详情