MySQL之控制函数

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 笔记

开发工具:

  • mysql-8.0
  • DataGrip

数据源:chapter8.csv

id,name,class,score
E001,张通,一班,98
E002,李谷,一班,68
E003,孙凤,一班,57
E004,赵恒,二班,47
E005,王娜,二班,84
E006,李伟,二班,70
E007,刘杰,三班,50
E008,薛李,三班,92
E009,裴军,三班,35


(1)if函数


现在我们要对某个分数进行判断,如果分数大于或等于60分,则返回“及格”,否则返回“不及格”,可以通过如下代码实现:

select if(50>=60,"及格","不及格")
-- 比如,我们要对chapter8表中的每位同学的成绩进行判断,可以通过如下代码实现:
select id,score,if(score >= 60,'及格','不及格') sorce_rst from demo.chapter8;
select id,score,if(score >= 60,if(score >= 70 ,'优秀','良好'),'不及格') sorce_rst from demo.chapter8;


(2)case when函数


上面我们讲了多层if嵌套,就是先判断condition是否满足某个条件,如果满足,则返回一个值或进行下一个if判断;如果不满足,则返回一个值或进行下一个if判断。虽然多层嵌套的原理比较简单,但是如果层数太多,读者还是会容易写混的,基于此,就有了这一节要讲的case when函数。case when函数主要有如下两种书写形式。


形式1:

case列名 when条件1 then返回值1 when条件2 then返回值2 ...... when条件n then返回值n else返回默认值 end

现在我们有这样一个需求,对chapter8表中class列的值进行替换,如果是一班,则返回class1;如果是二班,则返回class2;如果是三班,则返回class3,否则返回其他。这个需求可以通过如下代码实现:

select id,class,(case class
    when '一班' then 'class1'
    when '二班' then 'class2'
    when '三班' then 'class3'
    else '其他' end ) class_result from demo.chapter8;

形式2:

case when列名满足条件1 then返回值1 when列名满足条件2 then返回值2 ...... when列名满足条件n then返回值n else返回默认值 end

形式1不支持对列名进行比较运算,但是形式2是支持的,比如,前面讲过的多层if嵌套就可以通过形式2来实现,具体实现代码如下:

select id,score,(case when score < 60 then '不及格'
    when score < 80 then '良好'
    else '优秀' end ) sorce_rst from demo.chapter8;

在形式2中对列名进行比较运算时,我们除了可以利用小于运算,还可以利用在比较运算章节中介绍的其他运算,比如,我们可以把上面的多层if嵌套换一种实现方式来写,具体实现代码如下:

select id ,score ,
(case when score between 0 and 59 then "不及格" 
when score between 60 and 79 then "良好" else "优秀" end)score_result 
from demo.chapter8
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(2)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
2月前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(1)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
11天前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 `RIGHT` 函数
【8月更文挑战第8天】
62 7
在 MySQL 中使用 `RIGHT` 函数
|
11天前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 `REPLACE` 函数
【8月更文挑战第8天】
126 7
在 MySQL 中使用 `REPLACE` 函数
|
11天前
|
存储 SQL 关系型数据库
在 MySQL 中使用 `RTRIM` 函数
【8月更文挑战第8天】
47 8
在 MySQL 中使用 `RTRIM` 函数
|
14天前
|
缓存 关系型数据库 MySQL
在 MySQL 中使用 SPACE 函数
【8月更文挑战第5天】
50 3
在 MySQL 中使用 SPACE 函数
|
1月前
|
存储 JSON 关系型数据库
mysql中find_in_set()函数用法详解及增强函数
总结而言,`FIND_IN_SET()`是MySQL中处理由逗号分隔的字符串列表的一种便捷方法,尤其适用于列表相对较短且不经常更改的场景。然而,对于更为复杂的需要高性能和可扩展性的数据库设计,它可能不是最优选择,应考虑使用更加正规化的数据库结构。
55 2
mysql中find_in_set()函数用法详解及增强函数
|
1月前
|
关系型数据库 MySQL
mysql使用 CONCAT(字段,字段) 函数拼接
mysql使用 CONCAT(字段,字段) 函数拼接
|
29天前
|
存储 SQL 数据库
MySQL设计规约问题之为什么要避免使用存储过程、触发器和函数
MySQL设计规约问题之为什么要避免使用存储过程、触发器和函数
|
2月前
|
JSON 关系型数据库 MySQL
MySQL常用函数解读:从基础到进阶的全方位指南
MySQL常用函数解读:从基础到进阶的全方位指南