MySQL【内置函数】

一、日期函数

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。常用于解决查询结果中的空值问题,避免数据展示异常

相关推荐
HUGu RGIN5 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
HackTwoHub6 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t6 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK6 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)7 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
S1998_1997111609•X8 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK9 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
BU摆烂会噶10 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t11 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper11 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程