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

相关推荐
難釋懷2 小时前
Redis分片集群插槽原理
数据库·redis·缓存
冷小鱼2 小时前
pgvector 向量数据库完全指南:PostgreSQL 生态的 AI 增强
数据库·人工智能·postgresql
陈天伟教授2 小时前
人工智能应用- 天文学家的助手:08. 星系定位与分类
前端·javascript·数据库·人工智能·机器学习
yunyun321232 小时前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
m0_662577972 小时前
高级爬虫技巧:处理JavaScript渲染(Selenium)
jvm·数据库·python
ℳ๓₯㎕.空城旧梦3 小时前
Python单元测试(unittest)实战指南
jvm·数据库·python
Navicat中国3 小时前
Navicat 高效破解 SQL 编写繁琐难题,提升数据库设计效率
数据库·可视化·sql编写繁琐
Amctwd3 小时前
【数据库】常用 Sql 示例
数据库·sql·oracle
知识分享小能手4 小时前
Redis入门学习教程,从入门到精通,Redis 数据操作:知识点详解与代码实战(2)
数据库·redis·学习