SQL-按日期不间断统计
一、數據庫 日期數據不間斷
? ? ? ? ? ? ?SELECT COUNT(1) AS count, SUM(age) AS age FROM `user`
? ? ? ? ? ? ?GROUP BY DATE_FORMAT(create_time,'%Y-%m-%d');
?
二、數據庫 日期數據不連續 間斷補0
? ? ? ? ? ? ?1.不創建表方式 (臨時表 -- 只讀庫也可以創建)
? ? ? ? ? ? ?臨時表 只會存在一個查詢中,如果另開一個查詢則會
? ? ? ? ? ? ?sql error: table doesn't exist。
?
? ? ? ? ? ? ?CREATE TEMPORARY TABLE num (i int); -- 創建臨時表
? ? ? ? ? ? ?INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9); -- 插入增加的天數
? ? ? ? ? ? ?select adddate('2012-09-01', num.i) as `date` from num?
? ? ? ? ? ? ?where adddate('2012-09-01', num.i) <= '2012-09-10'; -- 查詢連續天數
? ? ? ? ? ? ?'2012-09-01' – 開始時間
? ? ? ? ? ? ?'2012-09-10' – 結束時間
? ? ? ? ? ? ?查詢結果:
? ? ? ? ? ? ?2012-09-01
? ? ? ? ? ? ?2012-09-02
? ? ? ? ? ? ?2012-09-03
? ? ? ? ? ? ?2012-09-04
? ? ? ? ? ? ?2012-09-05
? ? ? ? ? ? ?2012-09-06
? ? ? ? ? ? ?2012-09-07
? ? ? ? ? ? ?2012-09-08
? ? ? ? ? ? ?2012-09-09
? ? ? ? ? ? ?2012-09-10
? ? ? ? ? ? 備注: 如果需要增加連續的天數,則增加 num ?改變查詢的 開始 結束時間
? ? ? ? ? ? 例: 增加num 0 - 10000;開始時間為 2010-01-01? 結束時間為2018-12-31;
? ? ? ? ? ? 1.創建表方式 (臨時表 -- 只讀庫也可以創建)
CREATE TABLE num (i int);
INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9);
CREATE TABLE ?if not exists calendar(datelist date);?
INSERT INTO calendar (datelist) SELECT adddate( ( DATE_FORMAT("2018-01-01", '%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;
drop table num;
? ? ? ? ? ??"2018-01-01" --開始時間?
? ? ? ? ? ? 增加10000天。
天數連續的表有了, 在統計的時候就可以連續統計出來了。
?
?
?
另外: SUM()為空時,轉為0
? ? ? ? ? ? ? ? ? ? ? COALESCE(SUM(pay_amount),0)
保留兩位小數:
? ? ? ? ? ? ? ? ? ? ? ROUND(COALESCE(SUM(epc.pay_amount),0), 2)
?
?
?
?
?
?
?
?
?
?
總結
以上是生活随笔為你收集整理的SQL-按日期不间断统计的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 刚装修的房子多久能住?集成墙面真的好吗?
- 下一篇: 淘宝十年资深架构师吐血总结淘宝的数据库架