zoukankan      html  css  js  c++  java
  • 【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()这个函数,用法举例:

  • 相关阅读:
    【JAVA】日志管理slf4j
    【JAVA】从java线程来看java内存模型
    【数据结构】---栈和队列
    【数据结构】---链表
    C++ 第10章 反省程序与C++标准模板库
    回忆C++知识点(1)
    C++ 第8章 多态性
    C++ 第7章 继承与派生
    C++ 第6章 数组、指针、字符串
    C++ 第5章 数据的共享与保护
  • 原文地址:https://www.cnblogs.com/yangjian-java/p/6867132.html
Copyright © 2011-2022 走看看