• 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
  • 相关阅读:
    我给老师发的邮件
    [LeetCode]Sum Root to Leaf Numbers
    [LeetCode]Binary Tree Inorder Traversal
    [LeetCode]Merge Sorted Array
    [LeetCode]Unique Paths II
    [LeetCode]Unique Paths
    [LeetCode]Sort Colors
    [LeetCode]Balanced Binary Tree
    [LeetCode]Valid Palindrome
    [LeetCode]Binary Tree Maximum Path Sum
  • 原文地址:https://www.cnblogs.com/zhouziyan/p/12932647.html
Copyright © 2020-2023  润新知