Mysql获取当前周的起始和结束时间(详解每个函数)

首先介绍一下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' ) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

辅导猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值