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 ...
热门推荐
人心果的功效与作用、禁忌和食用方法
如何帮助毕业生做出合理的租房选择?这些选择需要考虑哪些因素?
韩国研发新型材料:能吸收99%以上电磁波
普法小课堂 | “虚假诉讼”知多少
央视制作的5部历史纪录片,评分都在8分以上!
人工智能中的自然语言处理
为什么接地电阻一般不大于4Ω?大于4Ω会有什么影响吗?
个人小微企业如何开具发票:合规与风险防控指南
晚上吃玉米会胖吗?
InnoDB引擎详解:存储结构、事务原理与MVCC机制
地球水的起源
《一念逍遥》法修仙界神通怎么排 法修仙界神通加点顺序推荐
常见小儿出疹性疾病的鉴别(附图)
居家徒手训练燃脂练肌肉,有氧运动会掉肌肉吗
专家进校园开展心理健康讲座:以互动形式助力学生预防校园欺凌
【体系管理】如何写好8D
出境入境时,如何顺利携带酒水?这些规定你必须知道!
军创赋能促发展!省、市军促会走进福田开展退役军人创业调研
高三刷题资料哪本好有效 高三好用的辅导资料推荐
苏州大学开发新型光催化剂:将聚酯废料转化为高附加值化学品
科学家系统综述光催化生成芳基自由基的研究现状和机理!
春运火车票开售首日:广州南站到潮汕方向多趟车票“秒光”
这就是江湖剑修如何进阶
老小区没有物业怎么办?三种管理方案任你选
广州荔湾区:引入社区 “微管家”,破解无物业老旧小区“无人管”难题
地下室是否计入建筑面积?建筑面积计算规范解读
补休加班费方面,具体有哪些规定
蜂蜜的存储:冰箱或地窖冷藏是否合适?
豆腐这样配,营养会翻倍!豆腐的“黄金搭档”,都是啥?
“每天吃豆三钱,何需服药连年”——关于豆类你了解多少?