mysql获取当前时间,前一天,后一天

Posted A Simple Note Book

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql获取当前时间,前一天,后一天相关的知识,希望对你有一定的参考价值。

负责的项目中,使用的是mysql数据库,页面上要显示当天所注册人数的数量,获取当前的年月日,我使用的是 CURDATE(),

错误的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()这个函数,用法举例:

  

今天是2016年08月01日。

date_sub(‘2016-08-01‘,interval 1 day) 表示 2016-07-31
date_sub(‘2016-08-01‘,interval 0 day) 表示 2016-08-01
date_sub(‘2016-08-01‘,interval -1 day) 表示 2016-08-02

date_sub(curdate(),interval 1 day) 表示 2016-07-31
date_sub(curdate(),interval -1 day) 2016-08-02
date_sub(curdate(),interval 1 month) 表示 2016-07-01
date_sub(curdate(),interval -1 month) 表示 2016-09-01
date_sub(curdate(),interval 1 year) 表示 2015-08-01
date_sub(curdate(),interval -1 year) 表示 2017-08-01

 

备注:

SELECT NOW(),CURDATE(),CURTIME()

结果类似:

NOW() CURDATE() CURTIME()
2016-08-01 16:25:46 2016-08-01 16:25:46
分类: Oracle数据库

以上是关于mysql获取当前时间,前一天,后一天的主要内容,如果未能解决你的问题,请参考以下文章

js如何去当前时间前一天的时间和后一天

sql函数--07---Mysql取前一天,前一周,后一天等时间函数

JSjs获取当前时间的前一天/后一天(昨天/明天)

获取当前时间的前一天或后一天时间

获取当前时间的前一天或后一天时间

获取当前日期的前一天,后一天