MySQL 常用函数全解析:字符串、数值、日期与流程函数
创作时间:
作者:
@小白创作中心
MySQL 常用函数全解析:字符串、数值、日期与流程函数
引用
CSDN
1.
https://blog.csdn.net/m0_73941339/article/details/146002734
MySQL中的函数主要分为四类:字符串函数、数值函数、日期函数和流程函数。本文将详细介绍这些函数的使用方法和应用场景,并通过具体案例帮助读者更好地理解和掌握这些函数。
一、字符串函数
MySQL中内置了很多字符串函数,常用的几个如下:
- concat:字符串拼接
- lower:全部转小写
- upper:全部转大写
- lpad:左填充
- rpad:右填充
- trim:去除空格
- substring:截取子字符串
案例:由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如:1号员工的工号应该为00001。
update emp set workno = lpad(workno, 5, '0');
处理完毕后,具体的数据为:
二、数值函数
常见的数值函数如下:
- ceil:向上取整
- floor:向下取整
- mod:取模
- rand:获取随机数
- round:四舍五入
案例:通过数据库的函数,生成一个六位数的随机验证码。
思路:获取随机数可以通过rand()函数,但是获取出来的随机数是在0-1之间的,所以可以在其基础上乘以1000000,然后舍弃小数部分,如果长度不足6位,补0
select lpad(round(rand()*1000000 , 0), 6, '0');
三、日期函数
常见的日期函数如下:
- curdate:当前日期
- curtime:当前时间
- now:当前日期和时间
- YEAR:当前年
- MONTH:当前月
- DAY:当前日
- date_add:增加指定的时间间隔
- datediff:获取两个日期相差的天数
案例:查询所有员工的入职天数,并根据入职天数倒序排序。
思路:入职天数,就是通过当前日期-入职日期,所以需要使用datediff函数来完成。
select name, datediff(curdate(), entrydate) as 'entrydays' from emp order by entrydays desc;
四、流程函数
流程函数也是很常用的一类函数,可以在SQL语句中实现条件筛选,从而提高语句的效率。
- if:条件判断函数
- ifnull:判断是否为NULL
- case when then else end:多条件判断
案例:查询学员的成绩等级
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 math >= 85 then '优秀' when math >=60 then '及格' else '不及格' end ) '数学',
(case when english >= 85 then '优秀' when english >=60 then '及格' else '不及格' end ) '英语',
(case when chinese >= 85 then '优秀' when chinese >=60 then '及格' else '不及格' end ) '语文'
from score;
MySQL的常见函数我们学习完了,那接下来,我们就来分析一下,在前面讲到的两个函数的案例场景,思考一下需要用到什么样的函数来实现?
- 数据库中,存储的是入职日期,如 2000-01-01,如何快速计算出入职天数呢? --------> 答案:datediff
- 数据库中,存储的是学生的分数值,如98、75,如何快速判定分数的等级呢? ----------> 答案:case ... when ...
热门推荐
情绪价值的秘密:如何掌控你的心理能量?
香港三大巴士公司齐加价,最高涨幅逾7%
中国古代教育制度:官学私学并行的千年传统
建立新型师生关系:从理解学生到共同成长
益生菌不能与什么一起吃?五大禁忌与迷思详解
肠道健康,佑安医者带你认识“第二大脑”
《第五人格》卡卡角色实战评测
研究证实:心肺功能好能多活6年,三种运动助你提升
LOL聊天设置与实战沟通技巧详解
英雄联盟升级社交功能,语音聊天将全球开放
菠菜馒头:传统美食的绿色创新
松软馒头DIY大赛,谁是烘焙达人?
优质小麦粉教你做出完美馒头
专家预测:2025年集装箱运费将维持4000-7000美元区间
AC+AP组网配置完全指南:从零到通
翠湖八景艺术墙亮相华山西路站,昆明地铁现网红打卡地
铂金VS铱金火花塞:谁才是高性能汽车的不二之选?
阴阳宅风水,现代家居的秘密武器
辛山乙向分金小空亡:古人的风水智慧
马来西亚虫鸣大地:万只蝴蝶打造沉浸式自然课堂
黄海水产研究所揭示七鳃鳗独特免疫细胞,为理解免疫进化提供新视角
全国95%地区水碘含量不足,食盐加碘仍是主要防治手段
资金短缺时的人际融资攻略:亲友、社交到债务重组
黑茶降糖有新证:安化黑茶结合智能系统,科学管理血糖
面对逆境如何快速恢复?解密心理学上的“抗逆力”
2024年经济形势严峻,专家建议这样理财和省钱
运动提升大脑功能,认知重构改变思维,情感沟通建立支持
每天一杯黑茶,远离糖尿病:最新研究证实降糖效果
一撇“丿”里的汉字智慧
手麻别大意:痛风和颈椎病的区分与预防指南