一、日期函数

1.1 基础获取时间 / 日期
-- 获取当前日期
select current_date(); -- 结果示例:2017-11-19
-- 获取当前时间
select current_time(); -- 结果示例:13:51:21
-- 获取当前时间戳(推荐now())
select current_timestamp(); -- 结果示例:2017-11-19 13:51:48
select now(); -- 与上一句结果一致



1.2 日期的增减运算
-- 日期加10天
select date_add('2017-10-28', interval 10 day); -- 结果:2017-11-07
-- 日期减2天
select date_sub('2017-10-01', interval 2 day); -- 结果:2017-09-29

1.3 计算两个日期的天数差
-- 计算2017-10-10与2016-09-01相差的天数
select datediff('2017-10-10', '2016-9-1'); -- 结果:404


1.4 案例
1)生日表:登记生日的日期

2)留言表时间处理 :
创建留言表并筛选 2 分钟内的留言,是非常典型的业务场景:
-- 创建留言表
create table msg (
id int primary key auto_increment,
content varchar(30) not null,
sendtime datetime -- 留言时间
);
-- 插入测试数据
insert into msg(content,sendtime) values('hello1', now());
insert into msg(content,sendtime) values('hello2', now());
-- 仅显示留言的日期(去除时间)
select content,date(sendtime) from msg;
-- 查询2分钟内发布的留言
select * from msg where date_add(sendtime, interval 2 minute) > now();

请查询在2分钟内发布的帖子:



二、字符串函数
字符串处理是 MySQL 开发的另一大高频需求,比如拼接字符串、替换字符、截取子串、获取字符长度等,掌握字符串函数能让文本数据的处理更灵活。

instr

ucase / lcase / length

left / right

rtrim/ltrim/trim

2.1 charset (str)
获取字符串的字符集
-- 获取EMP表中ename列的字符集
select charset(ename) from EMP;


2.2 concat (str1, str2, ...)
字符串拼接
常用于自定义结果展示格式,比如拼接学生成绩信息:
-- 格式:XXX的语文是XXX分,数学XXX分,英语XXX分
select concat(name, '的语文是',chinese,'分,数学是',math,'分,英语是',english,'分') as '分数' from student;


2.3 length (str)
获取字符串的字节长度
注意 :该函数按字节 计算长度,单字节字符(字母、数字)占 1 个字节,多字节字符(如中文)占多个字节(与字符集相关**,如 UTF-8 中中文占 3 个字节**)。
-- 查询学生姓名的字节长度
select length(name), name from student;

2.4 replace (str, old_str, new_str)
字符替换 , 将指定字符 / 子串替换为新的内容
注意,这里只是字符串级别的替换,不更改字符串这里的原始的数据!!!
-- 将EMP表中姓名里的'S'替换为'上海'
select replace(ename, 'S', '上海') as 新姓名,ename as 原姓名 from EMP;

2.5 substring (str, start, length)
截取子串
从指定位置开始,截取指定长度的子串**(注意:MySQL 中字符串起始位置为 1)**

2.6 lcase (str)/lower (str)
字符串转小写
结合截取函数,实现首字母小写的需求
-- 员工姓名首字母小写,其余不变
select concat(lcase(substring(ename, 1, 1)),substring(ename,2)) as 新姓名 from EMP;

三、数学函数
在处理数值型数据时,MySQL 的数学函数能实现绝对值、取整、四舍五入、生成随机数等操作,替代手动的数值计算逻辑。





四、其他函数
除了上述三类核心函数,MySQL 还有一些实用的通用函数,能解决用户查询、加密、空值处理等场景的问题,实用性拉满。
user ():查询当前登录 MySQL 的用户

database ():显示当前正在使用的数据库

加密相关函数
- md5(str) :对字符串进行 MD5 摘要,生成 32 位的加密字符串,常用于密码、敏感信息的轻量加密;
- password(str) :MySQL 专用的密码加密函数,生成加密后的字符串,用于数据库用户密码设置。
- 密码在数据库中不能明文保存,所以我们要对密码进行加密~


案例演示:



ifnull (val1, val2):空值处理神器
功能:如果 val1 为 NULL,则返回 val2;如果 val1 不为 NULL,则返回 val1。常用于解决查询结果中的空值问题,避免数据展示异常
