首先介绍一下Mysql中一些时间函数的用法
-- CURDATE()函数取的是当前的年月日,格式为2022-10-10
SELECT CURDATE()
-- WEEKDAY()函数取当前日期是这一周的第几天(注:该函数是以周日为一周的第一天,所以实际取值需要+1)
SELECT WEEKDAY(CURDATE()) -- 当前日期是2022/10/13 周四 输出结果为3
SELECT WEEKDAY('2022-10-01') -- 输出5,所以2022年国庆节这天为周六
-- DATE_SUB()函数需要搭配INTERVAL关键字使用,用于从日期减去指定的时间间隔
-- 获取指定时间10天前的日期,输出2022-10-03 10:00:00
SELECT DATE_SUB('2022-10-13 10:00:00',INTERVAL 10 DAY)
-- 获取指定时间5小时前的日期,输出2022-10-13 05:00:00
SELECT DATE_SUB('2022-10-13 10:00:00',INTERVAL 5 HOUR)
-- 获取本周的开始时间,输出2022-10-10(不含时分秒)
SELECT DATE_SUB( CURDATE(), INTERVAL WEEKDAY( CURDATE()) DAY )
-- DATE_ADD()函数与DATE_SUB()相反,用于从日期加上指定的时间间隔
-- 获取指定时间10天后的日期,输出2022-10-23 10:00:00
SELECT DATE_ADD('2022-10-13 10:00:00',INTERVAL 10 DAY)
-- 获取指定时间5小时后的日期,输出2022-10-13 15:00:00
SELECT DATE_ADD('2022-10-13 10:00:00',INTERVAL 5 HOUR)
-- DATE_FORMAT()函数,格式化日期时间
-- 输出2022-10-05 00:00:00,自动补充上时分秒
SELECT DATE_FORMAT('2022/10/5','%Y-%m-%d %H:%i:%s')
实例:
-- 获取本周的开始时间
SELECT DATE_FORMAT( DATE_SUB( CURDATE(), INTERVAL WEEKDAY( CURDATE()) DAY ), '%Y-%m-%d %H:%i:%s' )
-- 获取本周的结束时间
SELECT DATE_FORMAT( DATE_ADD( DATE_SUB( CURDATE(), INTERVAL WEEKDAY( CURDATE()) DAY ), INTERVAL 6 DAY ), '%Y-%m-%d 23:59:59' )