MySQL日期时间的处理函数

日期/时间处理函数

  • 获取当前日期时间函数

|------------|---------------|-----------------------------|---------------------|
| 函数 | 作用 | 示例 | 结果 |
| NOW() | 获取当前日期时间 | Select NOW() from dual; | 2025-12-31 13:16:20 |
| SYSDATE() | 获取系统时间,执行时的时间 | Select SYSDATE() from dual; | 2025-12-31 13:16:20 |
| CURDATAE() | 获取当前日期 | Select CURDATE() from dual; | 2025-12-31 |
| CURTIME() | 获取当前时间 | Select CURTIME() from dual; | 13:16:20 |

select NOW(), SYSDATE(), CURDATE(), CURTIME() from dual;

`NOW()` `SYSDATE()` `CURDATE()` `CURTIME()`

2025-12-31 13:16:20 2025-12-31 13:16:20 2025-12-31 13:16:20

  • 时间提取函数(拆分年/月/日/时/分/秒)

|-------------|------------|----|----------|
| 函数 | 作用 | 示例 | 结果 |
| YEAR() | 年 | | 2025 |
| MONTH() | 月 | | 12 |
| MONTHNAME() | 月份英文名 | | December |
| DAY() | 日 | | 31 |
| DAYOFWEEK() | 星期几(1=星期日) | | 4 |
| DAYOFYEAR() | 一年中第几天 | | 365 |
| HOUR() | 时 | | 13 |
| MINUTE() | 分 | | 16 |
| SECOND() | 秒 | | 20 |
| QUARTER() | 季度 | | 4 |

Select YEAR(NOW()), MONTH(NOW()), MONTHNAME(NOW()), DAY(NOW()), DAYOFWEEK(NOW()), DAYOFYEAR(NOW()), HOUR(NOW()), MINUTE(NOW()), SECOND(NOW()), QUARTER(NOW()) from dual;

`YEAR(NOW())` `MONTH(NOW())` `MONTHNAME(NOW())` `DAY(NOW())` `DAYOFWEEK(NOW())` `DAYOFYEAR(NOW())` `HOUR(NOW())` `MINUTE(NOW())` `SECOND(NOW())` `QUARTER(NOW())`

  1. 12 December 31 4 365 13 16 20 4
  • 时间格式化
  1. 时间格式-->字符串

语法:DATE_FORMAT(时间字段,'格式字符串')

常用格式符:

%Y--4位年;%y--2位年;%m--2位月(补0);%c--1位月;%d--2位日(补0);%e--1位日;

%H--24小时制;%h--12小时制;%i--分钟;%s秒

DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s')----2025-12-31 13:16:20

DATE_FORMAT(now(), '%Y-%m-%d')----2025-12-31

DATE_FORMAT(NOW(), '%Y年%m月%d日')----2025年12月31日

DATE_FORMAT(NOW(), '%Y%m')--202512

  1. 字符串-->时间格式

语法:STR_TO_DATE('字符串', '格式格式串')

常用格式符:

%Y--4位年;%y--2位年;%m--2位月(补0);%c--1位月;%d--2位日(补0);%e--1位日;

%H--24小时制;%h--12小时制;%i--分钟;%s秒

STR_TO_DATE('2025/06/06','%Y/%m/%d')----2025-06-06

STR_TO_DATE('20251231', '%Y%m%d')----2025-12-31

STR_TO_DATE('20250801111213','%Y%m%d%H%i%s')----2025-08-01 11:12:13

  • 时间计算函数(加减/相差计算)
  1. 加减计算的语法:

DATE_ADD(时间字段, INTERVAL 数值 单位) -- 加时间

DATE_SUB(时间字段, INTERVAL 数值 单位) -- 减时间

支持单位:YEAR/MONTH/DAY/HOUR/MINUTE/SECOND/WEEK/QUARTER

select NOW(), DATE_ADD(NOW(), interval 2 DAY), DATE_ADD(NOW(), interval 1 MONTH) from dual;

2026-01-05 10:00:00 2026-01-07 10:00:00 2026-02-05 10:00:00

select NOW(), DATE_SUB(NOW(), interval 2 DAY), DATE_SUB(NOW(), interval 2 YEAR) from dual;

2026-01-05 10:00:00 2026-01-03 10:00:00 2024-01-05 10:00:00

  1. 日期的相差(DATEDIFF()/TIMESTAMPDIFF())

|-----------------|------------|-------------------------------|----------------------------------------------|
| 函数 | 作用 | 语法 | 示例 |
| DATEDIFF() | 计算两个日期的天数差 | DATEDIFF(日期1, 日期2) | DATEDIFF('2026-01-10', NOW()) --5 |
| TIMESTAMPDIFF() | 计算任意单位的时间差 | TIMESTAMPDIFF(单位, 开始时间, 结束时间) | TIMESTAMPDIFF(hour, '2026-01-05',NOW()) --14 |

  1. 特殊计算:

LAST_DAY():获取指定日期所在月份的最后一天。

DATE():提取时间字段的日期部分(忽略时分秒)

select last_day(now()), date(NOW()) from dual;

2026-01-31 2026-01-05

  • 特定时间

1、当天、昨天、明天、本月初、本月末、上月的今天、上月初、上月末、

今年年初、今年的年末、去年的今天、去年初、去年末。

select '今天' as '日期', date(NOW()) from dual union all

select '昨天' as '日期', DATE_SUB(date(NOW()), interval 1 day) from dual union all

select '明天' as '日期', DATE_ADD(date(NOW()), interval 1 day) from dual union all

select '当月初' as '日期', DATE_ADD(last_day(DATE_SUB(date(NOW()), interval 1 month)), interval 1 day) from dual union all

select '当月末' as '日期', last_day(date(NOW())) from dual union all

select '上月的今天' as '日期', DATE_SUB(date(NOW()), interval 1 month) from dual union all

select '上月初' as '日期', DATE_ADD(last_day(DATE_SUB(date(NOW()), interval 2 month)), interval 1 day) from dual union all

select '上月末' as '日期', last_day(DATE_SUB(date(NOW()), interval 1 month)) from dual union all

select '今年初' as '日期', DATE_FORMAT(CURDATE(), '%Y-01-01') from dual union all

select '今年末' as '日期', DATE_FORMAT(CURDATE(), '%Y-12-31') from dual;

|-------|------------|---|
| 日期 | 结果 | |
| 今天 | 2026-01-07 | |
| 昨天 | 2026-01-06 | |
| 明天 | 2026-01-08 | |
| 当月初 | 2026-01-01 | |
| 当月末 | 2026-01-31 | |
| 上月的今天 | 2025-12-07 | |
| 上月初 | 2025-12-01 | |
| 上月末 | 2025-12-31 | |
| 今年初 | 2026-01-01 | |
| 今年末 | 2026-12-31 | |

2、对于闰年2月末,平年2月末的问题

select DATE_SUB(date('2026-03-31'), interval 1 month) from dual; -- 2026-02-28

select DATE_ADD(date('2024-02-29'), interval 1 year) from dual; -- 2025-02-28

3、当天是本年度的第几天

当天是本周几:1=周日;2=周一;3=周二;4=周三;5=周四;6=周五;7=周六。

select dayofyear(now()) from dual; --7

select dayofweek(now()) from dual; --4

4、周几转化成中文星期

select case DAYOFWEEK(NOW())

when 1 then '周日'

when 2 then '周一'

when 3 then '周二'

when 4 then '周三'

when 5 then '周四'

when 6 then '周五'

when 7 then '周六'

end

as week_day_cn from dual;

相关推荐
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest3 天前
数据库SQL学习
数据库·sql
jnrjian3 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle
十月南城3 天前
数据湖技术对比——Iceberg、Hudi、Delta的表格格式与维护策略
大数据·数据库·数据仓库·hive·hadoop·spark