负责的项目中,使用的是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

最新文章

  1. Android 启动后页面跳转
  2. BZOJ 1588: [HNOI2002]营业额统计
  3. REST服务中的异常处理
  4. [UWP]一种利用Behavior 将StateTrigger集中管理的方案
  5. 泛函编程(11)-延后计算-lazy evaluation
  6. linux(Debian)下安装与MySql的安装、卸载、配置及使用
  7. windows32下安装zend framework2
  8. ocp 1Z0-042 61-120题解析
  9. Java笔记(一)&hellip;&hellip;概述
  10. 2014年辛星Javascript解读第二节
  11. BZOJ 1452: [JSOI2009]Count(二维BIT)
  12. 点击grid单元格弹出新窗口
  13. ABP框架个人开发实战(1)_环境搭建
  14. Treap(树堆)
  15. bzoj 3745: [Coci2015]Norma
  16. IBM小练习
  17. svn ignore 的用法
  18. ffplay源码分析2-数据结构
  19. WordPress主题开发:截取标题或内容
  20. Centos 模拟生成文件的脚本

热门文章

  1. SharePoint 2016 每天预热脚本介绍
  2. Nio经典工作方式
  3. Spring 学习一
  4. date时间转换
  5. SQL联表查询
  6. createjs 小游戏开发实战
  7. Vijos 1025 小飞侠的游园方案 0-1背包
  8. Educational Codeforces Round 22.B 暴力
  9. VB6之SOAP
  10. OpenCV 之 网络摄像头