【MySQL】MySQL函数学习和总结

🌈个人主页: Aileen_0v0
🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法

💫个人格言:"没有罗马,那就自己创造罗马~"
ask for the moon异想天开

文章目录

函数

流程函数

流程函数:可在SQL语句中实现条件筛选,提高语句效率。

函数 功能
if(value,t,f) 如果value为true,则返回t,否则返回f
ifnull(value1,value2) 如果value1不为空,则返回value1,否则返回value2
case when [ val1 ] then [ res1 ] ... else [ default ] end 如果val1为true,返回
case [ expr ] when [ val1 ] then [ res1 ] ... else [ default ] end 如果expr的值等于val1,返回res1,... 否则返回default默认值

if函数

sql 复制代码
-- 流程控制函数
-- if
select if(false,'Aileen','Betty');

ifnull函数

sql 复制代码
-- ifnull
select  ifnull('ok','default');
sql 复制代码
select  ifnull('','default');
sql 复制代码
select  ifnull(null, 'default');

case函数

sql 复制代码
-- case when then else end
-- 需求: 查询emp 表的员工姓名和工作地址(北京/上海 ----> 一线城市 , 其他 ----> 二线城市)

-- 首先将员工姓名和工作地址先筛选出来
select name,WORKADDRESS from emp;

-- 再根据需求进行条件筛选
 select
       name,
       case WORKADDRESS when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end
from emp;

case函数

将分数转换为等级

sql 复制代码
-- 案例: 统计班级各学员的成绩,展示的规则如下:
-- >= 85, 展示优秀
-- >= 60, 展示及格
-- 否则, 展示不及格

create table score(
    id int comment  'ID',
    name varchar(20) comment '姓名',
    math int comment  '数学',
    english int comment '英语',
    chinese int comment '语文'
) comment '学员成绩表';
insert into score(id, name, math, english, chinese) values (1,'Tom',67,88,95),(2,'Rose',23,66,90),(3,'Jack',56,98,76);

select
    id,
    name,
    (case when chinese >= 85 then '优秀' when chinese >= 60 then '及格' else '不及格' end ) '语文',
    (case when english >= 85 then '优秀' when english >= 60 then '及格' else '不及格' end ) '英语',
    (case when math >= 85 then '优秀' when math >= 60 then '及格' else '不及格' end ) '数学'
from score;



函数总结


Exercises

计算我加入CSDN的时间

sql 复制代码
select datediff('2024-2-12','2023-3-14');

相关推荐
zhangchaoxies2 分钟前
JavaScript中Tree-shaking失效的场景及其优化对策
jvm·数据库·python
山峰哥2 分钟前
SQL性能飞跃:从索引策略到查询优化的全链路实战指南
数据库·sql·性能优化·深度优先
2501_914245932 分钟前
SQL在GROUP BY中如何保留非聚合列_配合ANY_VALUE或窗口函数
jvm·数据库·python
weixin_580614003 分钟前
如何防止SQL注入篡改数据_实施双重身份验证与授权
jvm·数据库·python
2401_897190554 分钟前
SQL视图占空间吗_理解视图定义与存储机制的底层逻辑
jvm·数据库·python
qq_424098566 分钟前
C#怎么实现UDP广播通信_C#如何搭建Socket网络【核心】
jvm·数据库·python
2501_914245936 分钟前
Python Web开发如何防范SQL注入_使用参数化查询与ORM实践
jvm·数据库·python
fy121637 分钟前
【SQL】写SQL查询时,常用到的日期函数
数据库·sql
yejqvow128 分钟前
Golang怎么做模糊测试fuzz_Golang Fuzz测试教程【高效】
jvm·数据库·python
2401_897190559 分钟前
mysql如何通过mysqldump备份视图与触发器_使用相关参数
jvm·数据库·python