zoukankan      html  css  js  c++  java
  • mySql 查询当天、本周、最近7天、本月、最近30天的语句

    -- 当天

    SELECT * FROM  表名 WHERE where to_days(时间字段名) = to_days(now());

    -- 本周

    SELECT * FROM  表名 WHERE YEARWEEK(date_format(时间字段,'%Y-%m-%d')) = YEARWEEK(now());

    -- 最近7天

    SELECT * FROM  表名  where date_sub(curdate(), INTERVAL 7 DAY) <= date (时间字段);

    -- 本月

    SELECT * FROM  表名 where date_format(时间字段, '%Y%m') = date_format(curdate() , '%Y%m');

    -- 最近30天

     * FROM  表名 WHERE date_sub(curdate(), INTERVAL 30 DAY) <= date(时间字段);

    -- 上一月


    SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1
    
    -- 本季度
    SELECT * FROM 表名  WHERE QUARTER(create_date)=QUARTER(now());
    

    查询上季度数据

    SELECT * FROM  表名 WHERE QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

    查询本年数据

    SELECT * FROM  表名 WHERE YEAR(create_date)=YEAR(NOW());

    查询上年数据

    SELECT * FROM  表名 WHERE year(create_date)=year(date_sub(now(),interval 1 year));

    查询上周的数据

    SELECT * FROM  表名 WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now())-1;

    查询上个月的数据

    复制代码
    复制代码
    SELECT * FROM  表名 WHERE date_format(submittime,'%Y-%m')=date_format(DATE_SUB(curdate(), INTERVAL 1 MONTH),'%Y-%m')

    SELECT * FROM  表名 WHERE DATE_FORMAT(pudate,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m') ;
    SELECT * FROM  表名 WHERE WEEKOFYEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = WEEKOFYEAR(now())

    SELECT * FROM  表名 WHERE MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now())

    SELECT * FROM  表名 WHERE YEAR(FROM_UNIXTIME(pudate,'%y-%m-%d')) = YEAR(now()) and MONTH(FROM_UNIXTIME(pudate,'%y-%m-%d')) = MONTH(now())

    SELECT * FROM  表名 WHERE pudate between 上月最后一天 and 下月第一天

    复制代码
    复制代码

    查询距离当前现在6个月的数据

    SELECT * FROM  表名 WHERE submittime between date_sub(now(),interval 6 month) and now();

    • 查询当天的所有数据
    SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())=0
    • 查询昨天的所有数据
    SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())=-1
    • 查询未来第n天的所有数据
    //当n为负数时,表示过去第n天的数据
    SELECT * FROM 表名WHERE DATEDIFF(字段,NOW())=n
    • 查询未来n天内所有数据
    //n天内
    SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())<n AND DATEDIFF(字段,NOW())>=0
    • 查询过去n天内所有数据
    //包含当天
    SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())<=0 AND DATEDIFF(字段,NOW())>-n
    //不包含当天
    SELECT * FROM 表名 WHERE DATEDIFF(字段,NOW())<0 AND DATEDIFF(字段,NOW())>-n
  • 相关阅读:
    Pycharm 中的翻译工具
    服务器响应慢问题
    将博客搬至CSDN
    【索引】索引的介绍与优化
    【Java杂记】Equals 和 hashCode
    【Java】JVM(六)虚拟机字节码执行引擎
    【Java】JVM(五)、虚拟机类加载机制
    【Java】JVM(四)、虚拟机参数配置
    【Java】JVM(三)、Java垃圾收集器
    【Java】JVM(二)、Java垃圾收集算法
  • 原文地址:https://www.cnblogs.com/zhouziyan/p/12932647.html
Copyright © 2011-2022 走看看