• mysql中的年,月,日统计以及日历表的实现


    日历表的实现

    创建日历表脚本
    首先,日历表的创建和数据的插入如果自己手写,确实麻烦的不行,但是刚刚说的前人的轮子也不是吃素的,如下脚本:

    CREATE TABLE num (i int);-- 创建一个表用来储存0-9的数字
    INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9);-- 生成0-9的数字,方便以后计算时间
     
    CREATE TABLE  if not exists calendar(datelist date); -- 生成一个存储日期的表,datalist是字段名
     
    -- 这里是生成并插入日期数据
    INSERT INTO calendar(datelist) SELECT
        adddate(
            (   -- 这里的起始日期,你可以换成当前日期
                DATE_FORMAT("2018-1-1", '%Y-%m-%d') 
            ),
            numlist.id
        ) AS `date`
    FROM
        (
            SELECT
                n1.i + n10.i * 10 + n100.i * 100 + n1000.i * 1000+ n10000.i * 10000 AS id
            FROM
                num n1
            CROSS JOIN num AS n10
            CROSS JOIN num AS n100
            CROSS JOIN num AS n1000
            CROSS JOIN num AS n10000
        ) AS numlist;
    
    按日期统计

    SELECT
        c.datelist as date,
        COUNT(b.id) as count
    FROM
        calendar AS c
    LEFT JOIN (
        SELECT
            *
        FROM
            driver -- 真正想统计的表名
        WHERE
            lnvalid = 2 -- 这个是查询条件,你们酌情写自己的
        AND flag = 0 -- 这个是查询条件,你们酌情写自己的
    ) AS b ON c.datelist = DATE(b.create_time)  -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等
    WHERE
        c.datelist LIKE '2019-10%'       -- 这个是查询某月的日期统计,在代码中这块应该是一个参数。我这里查询的2019年10月份的统计
    GROUP BY
        datelist  -- 这个分组按照日期分组,再次声明这个是天的,如果月的这里会不同
    ORDER BY
        datelist   -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
    
    按月份统计
    SELECT
        DATE_FORMAT(c.datelist, '%Y-%m') as date, -- 查询的是年-月,所以要格式处理
        COUNT(b.id) as count
    FROM
        calendar AS c
    LEFT JOIN (
        SELECT
            *
        FROM
            driver -- 真正想统计的表名
        WHERE
            lnvalid = 2 -- 这个是查询条件,你们酌情写自己的
        AND flag = 0 -- 这个是查询条件,你们酌情写自己的
    ) AS b ON c.datelist = DATE(b.create_time)  -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等
    WHERE
        c.datelist LIKE '2019%'      -- 这个是查询某月的日期统计,在代码中这块应该是一个参数。我这里查询的2019年的统计
    GROUP BY
        DATE_FORMAT(c.datelist, '%Y-%m')-- 这个分组按照月份分组的,因为datelist是年月日,所以要格式化处理成年月
    ORDER BY
        datelist   -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
    


    按照年统计
    SELECT
        DATE_FORMAT(c.datelist, '%Y') as date, -- 查询的是年,所以要格式处理
        COUNT(b.id) as count
    FROM
        calendar AS c
    LEFT JOIN (
        SELECT
            *
        FROM
            base_driver -- 真正想统计的表名
        WHERE
            if_lnvalid = 2 -- 这个是查询条件,你们酌情写自己的
        AND flag = 0 -- 这个是查询条件,你们酌情写自己的
    ) AS b ON c.datelist = DATE(b.create_time)  -- 两个表的关联,因为我表中crate_time是年月日时分秒的,所以要格式化后相等
    GROUP BY
        DATE_FORMAT(c.datelist, '%Y')-- 这个分组按照月份分组的,因为datelist是年月日,所以要格式化处理成年
    ORDER BY
        datelist   -- 这个排序是因为之前一次测试有count的在上面,没有的在下面,日期没有顺序,所以我又升序排了下。
    





  • 相关阅读:
    MySql错误解决方案汇总
    不适合做管理的人zz
    linux 自动执行 crontab学习笔记
    Google Megastore分布式存储技术全揭秘zz
    【算法】n个人围成一圈报数,报到3的退出,下面接着从1开始报,问最后剩下的是谁?
    大数据下的数据分析平台架构zz
    ETL的可扩展性和可维护性zz
    【算法】各种排序算法测试代码
    谈爱情故事,谈观察者模式
    解读设计模式单例模式(Singleton Pattern)
  • 原文地址:https://www.cnblogs.com/liangmm/p/12938597.html
Copyright © 2020-2023  润新知