【技术】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());
相关推荐
奶糖趣多多43 分钟前
Redis知识点
数据库·redis·缓存
CoderIsArt2 小时前
Redis的三种模式:主从模式,哨兵与集群模式
数据库·redis·缓存
师太,答应老衲吧4 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
Yaml45 小时前
Spring Boot 与 Vue 共筑二手书籍交易卓越平台
java·spring boot·后端·mysql·spring·vue·二手书籍
Channing Lewis5 小时前
salesforce case可以新建一个roll up 字段,统计出这个case下的email数量吗
数据库·salesforce
追风林5 小时前
mac 本地docker-mysql主从复制部署
mysql·macos·docker
毕业设计制作和分享6 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
ketil276 小时前
Redis - String 字符串
数据库·redis·缓存
Hsu_kk7 小时前
MySQL 批量删除海量数据的几种方法
数据库·mysql
编程学无止境7 小时前
第02章 MySQL环境搭建
数据库·mysql