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 ...
热门推荐
郭俣浩推荐:舞蹈生的科学饮食指南
舞蹈生科学饮食指南:从营养需求到实用方案
深度学习情感识别:从入门到实践
婚前财产律师咨询:如何保护自己的权益?
立冬吃饺子,如何带动地方经济?
春节民俗大揭秘:从祭灶到扫尘
春节古诗大挑战:你敢接招吗?
冰柜节能小妙招,你get了吗?
双十一囤货后,你的冰柜还好吗?
肇庆两日游:打卡七星岩和鼎湖山,感受岭南名城魅力
肇庆星湖湿地公园亲子游攻略:丹顶鹤生态园全新开放!
肇庆古城墙:千年守护者的今昔
西安康宁心理医院医生详解:抑郁出现哪些负面情况需及时就医?
抑郁症防复发小策略
大额存单投资全攻略:从选购到风险防范
银行大额存单:理财新宠?
国有四大行大额存单利率跌至“1字头”
油莎豆:营养价值高、用途广泛的“油料植物之王”
油莎豆:粮油安全可持续发展的新希望
探秘油莎豆,健康食品中的宝藏
用好特病单议等管理机制,罕见病并不是“低分”病种
黄金作为投资品的属性有哪些?这些属性如何影响其市场表现和投资价值?
投资组合多样化的策略与优势
地缘政治阴霾下的金融市场变局|达沃斯声音
开学了,怎么帮助孩子适应新学期?
孩子刚上小学,如何与学校老师有效沟通了解在校表现
家长如何有效参加家长会?要做好“备”“看” “听” “问”
《我的世界》新手必看:快速找到钻石的秘诀!
掌握《我的世界》钻石矿脉生成规律,高效挖矿攻略!
《我的世界》1.20版高效挖钻攻略:最佳深度与技巧详解