日歷表的實現
創建日歷表腳本
首先,日歷表的創建和數據的插入如果自己手寫,確實麻煩的不行,但是剛剛說的前人的輪子也不是吃素的,如下腳本:
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的在上面,沒有的在下面,日期沒有順序,所以我又升序排了下。
