错误的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()这个函数,用法举例:
例如生日提前几天的获取:
SELECT * FROM ls_bs_vipinfo
WHERE
DATE_FORMAT(CSNY,'%m/%d')= DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL 5 DAY),'%m/%d')
备注:CSNY字段表示会员生日,后面的根据当天日期往后加5天进行对比查询
SYSDATE() >= start_time AND SYSDATE() <= DATE_SUB(end_time,INTERVAL -1 DAY)
备注:查询当前时间的范围是否满足 ,结束时间按照当天来计算
条件BETWEEN (SELECT DATE_ADD(NOW(),INTERVAL -1 MONTH)) AND NOW();
备注:查询上个月到现在的数据
今天是2017年07月14日。
date_sub('2016-08-01',interval 1 day) 表示 2017-07-13
date_sub('2016-08-01',interval 0 day) 表示 2017-07-14
date_sub('2016-08-01',interval -1 day) 表示 2017-07-15
date_sub(curdate(),interval 1 day) 表示 2017-07-13
date_sub(curdate(),interval -1 day) 2017-07-15
date_sub(curdate(),interval 1 month) 表示 2017-07-14
date_sub(curdate(),interval -1 month) 表示 2017-08-14
date_sub(curdate(),interval 1 year) 表示 2016-07-14
date_sub(curdate(),interval -1 year) 表示 2018-07-14