【技术】MySQL 日期时间操作

MySQL 日期时间操作

  • [MySQL 系统时间](#MySQL 系统时间)
  • [MySQL 时间格式化](#MySQL 时间格式化)
  • [MySQL 年月日时分秒周](#MySQL 年月日时分秒周)
  • [MySQL 日期计算](#MySQL 日期计算)

MySQL 系统时间

  • now():系统时间,年月日时分秒
  • current_date:系统时间,年月日
  • current_time:系统时间,时分秒
  • current_timestamp:系统时间,年月日时分秒
sql 复制代码
select now(), current_date, current_time, current_timestamp

MySQL 时间格式化

  • date_format(time, format_str):对时间进行格式化,返回字符类型。第一个参数为日期,第二个参数为格式化字符串。
  • str_to_date(time_str, format_str):对字符串类型的日期进行格式化,返回日期类型。第一个参数为时间字符串,第二个参数为格式化字符串
  • format_str 含义:
    %y:2位年份
    %Y:4位年
    %m:数字月份
    %M:英语月份
    %d:日
    %h:12小时制
    %H:24小时制
    %i:分钟
    %s:秒
  • hour(time):获取小时
  • minute(time):获取分钟
  • second(time):获取秒
sql 复制代码
select date_format(now(), '%y-%m-%d %h:%i:%s');
SELECT str_to_date('2023-12-20 11:30:35','%Y-%m-%d %h:%i:%s');


MySQL 年月日时分秒周

  • year(time):获取时间中的年
  • month(time):获取时间中的月份
  • day(time):获取时间中的天
  • hour(time):获取时间中的小时(24小时)
  • minute(time):获取时间中的分钟
  • second(time):获取时间中的秒
  • dayofyear(time):获取时间中的天在本年中的天数。
  • dayofmonth(time):获取时间中的天在月中的天数。
  • dayofweek(time):获取时间中的天在本周中的天数,即周几,从周日开始,返回下标,下标从1开始。
  • dayname(time):获取时间中的天在本周中的天数,即周几,返回周的英语单词。
  • weekday(time):获取时间中的天在本周中的天数,即周几,从周一开始,返回下标,下标从0开始。
sql 复制代码
# 年月日
select year(now()), month(now()), day(now());
# 时分秒
select hour(now()), minute(now()), second(now());
# 天数
select dayofmonth(now()), dayofweek(now()), dayofyear(now());
# 周数
select dayname(now()), weekday(now()), dayofweek(now());

MySQL 日期计算

时分秒时差

  • timediff(end, start):时分秒时间差,返回格式为时分秒。可以搭配相关日期函数获取时分秒单个值。
sql 复制代码
select start, end, timediff(end, start) from date_test;

日期差

  • timestampdiff(time_flg, time1, time2):计算两个日期之间的时间差,根据指定的时间标识,可以获取年月日时分秒。注意 time_flg 时间标识大写。
sql 复制代码
select start, end, timestampdiff(YEAR , start, end) from date_test;
select start, end, timestampdiff(MONTH , start, end) from date_test;
select start, end, timestampdiff(DAY , start, end) from date_test;
select start, end, timestampdiff(HOUR , start, end) from date_test;
select start, end, timestampdiff(MINUTE , start, end) from date_test;
select start, end, timestampdiff(SECOND , start, end) from date_test;

日期加减

  • date_add(date, INTERVAL expr type):日期增加函数。第一个参数是当前时间。第二个参数 INTERVAL 是固定写法,expr 是增加的时间的表达式。type为增加的单位。
  • date_sub(date, INTERVAL expr type):日期增加函数。第一个参数是当前时间。第二个参数 INTERVAL 是固定写法,expr 是减少的时间的表达式。type为增加的单位。
sql 复制代码
# 获取 7 天前的日期,注意 INTERVAL 后面表达式的区别
select date_add(now(), INTERVAL -7 day), date_sub(now(), INTERVAL 7 day);

# 获取 7 天后的日期,注意 INTERVAL 后面表达式的区别
select date_add(now(), INTERVAL 7 day), date_sub(now(), INTERVAL -7 day);

-- 本周开始
select date_sub(curdate(), INTERVAL WEEKDAY(curdate()) DAY);
-- 本周结束
select date_sub(curdate(), INTERVAL WEEKDAY(curdate()) - 6 DAY);
-- 本月开始
select date_sub(curdate(), INTERVAL DAYOFMONTH(curdate()) -1 DAY);
-- 本月结束
select last_day(curdate());
相关推荐
这个DBA有点耶2 分钟前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶2 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技3 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend3 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence7 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql