【msyql_获取时间的前后几天函数date_sub】
select now()-- 2017-05-16 16:48:02
select curdate() -- 2017-05-16
select curdate() + 1 -- 20170517
select curtime() -- 16:48:21
select date_sub(CURDATE(),interval + 1 DAY) -- 2017-05-15
select date_sub(CURDATE(),interval 0 DAY) -- 2017-05-16
select date_sub(CURDATE(),interval + 1 DAY) -- 2017-05-17
select date_sub(curdate(),interval 1 month) -- 2017-04-16
select date_sub(curdate(),interval -1 month) -- 2017-06-16
select date_sub(curdate(),interval 1 year) -- 2016-05-16
select date_sub(curdate(),interval -1 year) -- 2018-05-16
例子:
错误的sql语句
eg:SELECT COUNT(*) FROM USER WHERE registerDate >= CURDATE() AND registerDate < CURDATE()+1;
虽然 获取到的数量在测试环境中是正确的,但在发布到线上的时候,发现有的时候数据是查询不到,数量为0,因此,就上网查询是不是CURDATE()+1不规范,发现mysql官网也是不承认时间直接相加减的,虽然会将当前时间转换为20160802,这时候就是比较这一串字符,mysql官网是不承认用这种方式比较时间大小的,因此:
正确的sql语句
eg:SELECT COUNT(*) FROM USER WHERE registerDate >= CURDATE() AND registerDate < DATE_SUB(CURDATE(),INTERVAL -1 DAY);
此时,就用到了DATE_SUB()这个函数,用法举例:
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步