【技术】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());
相关推荐
摘星怪sec17 分钟前
【漏洞复现】|方正畅享全媒体新闻采编系统reportCenter.do/screen.do存在SQL注入
数据库·sql·web安全·媒体·漏洞复现
基哥的奋斗历程26 分钟前
学到一些小知识关于Maven 与 logback 与 jpa 日志
java·数据库·maven
苏-言33 分钟前
MyBatis最佳实践:提升数据库交互效率的秘密武器
数据库·mybatis
gyeolhada1 小时前
计算机组成原理(计算机系统3)--实验八:处理器结构拓展实验
java·前端·数据库·嵌入式硬件
码农丁丁1 小时前
为什么数据库不应该使用外键
数据库·mysql·oracle·数据库设计·外键
随心Coding3 小时前
【MySQL】存储引擎有哪些?区别是什么?
数据库·mysql
m0_748237054 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
dal118网工任子仪5 小时前
61,【1】BUUCTF WEB BUU XSS COURSE 11
前端·数据库·xss
萌小丹Fighting6 小时前
【Postgres_Python】使用python脚本批量创建和导入多个PG数据库
数据库
青灯文案16 小时前
Oracle 数据库常见字段类型大全及详细解析
数据库·oracle