原文 ---------> https://blog.csdn.net/csdn_ds/article/details/71728164
负责的项目中,使用的是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 DATE_FORMAT(NOW(),’%b %d %Y %h:%i %p’);
- 显示当前日期的年月日:SELECT DATE_FORMAT(NOW(),’%Y-%m-%d’);
- W3Cshcool中关于 mysql中函数的讲解 http://www.w3school.com.cn/sql/sql_dates.asp
DATE() | 提取日期或日期/时间表达式的日期部分 |
EXTRACT() | 返回日期/时间按的单独部分 |
DATE_ADD() | 给日期添加指定的时间间隔 |
DATE_SUB() | 从日期减去指定的时间间隔 |
DATEDIFF() | 返回两个日期之间的天数 |
DATE_FORMAT() | 用不同的格式显示日期/时间 |
备注:
SELECT NOW(),CURDATE(),CURTIME()
结果类似:
NOW() | CURDATE() | CURTIME() |
---|---|---|
2016-08-01 16:25:46 | 2016-08-01 | 16:25:46 |
js中如果显示的是毫秒数或者不规则的时间可以先将时间转化一下
function formateDate(str){
var datenow=new Date(str);
var xdate=datenow.getFullYear()+"-"+(datenow.getMonth()+1)+"-"+datenow.getDate();
return xdate;
}
获取一个时间的 后 8天
function fun_submit(arg){
var date1 = new Date();
var xdate=date1.getFullYear()+"-"+(date1.getMonth()+1)+"-"+date1.getDate();
Date.parse(xdate.replace());
var date2 = new Date(date1);
date2.setDate(date1.getDate()+8);
var times = date2.getFullYear()+"-"+(date2.getMonth()+1)+"-"+date2.getDate();
alert(times);
}