SQL-按日期不间断统计
一、數(shù)據(jù)庫(kù) 日期數(shù)據(jù)不間斷
? ? ? ? ? ? ?SELECT COUNT(1) AS count, SUM(age) AS age FROM `user`
? ? ? ? ? ? ?GROUP BY DATE_FORMAT(create_time,'%Y-%m-%d');
?
二、數(shù)據(jù)庫(kù) 日期數(shù)據(jù)不連續(xù) 間斷補(bǔ)0
? ? ? ? ? ? ?1.不創(chuàng)建表方式 (臨時(shí)表 -- 只讀庫(kù)也可以創(chuàng)建)
? ? ? ? ? ? ?臨時(shí)表 只會(huì)存在一個(gè)查詢中,如果另開一個(gè)查詢則會(huì)
? ? ? ? ? ? ?sql error: table doesn't exist。
?
? ? ? ? ? ? ?CREATE TEMPORARY TABLE num (i int); -- 創(chuàng)建臨時(shí)表
? ? ? ? ? ? ?INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9); -- 插入增加的天數(shù)
? ? ? ? ? ? ?select adddate('2012-09-01', num.i) as `date` from num?
? ? ? ? ? ? ?where adddate('2012-09-01', num.i) <= '2012-09-10'; -- 查詢連續(xù)天數(shù)
? ? ? ? ? ? ?'2012-09-01' – 開始時(shí)間
? ? ? ? ? ? ?'2012-09-10' – 結(jié)束時(shí)間
? ? ? ? ? ? ?查詢結(jié)果:
? ? ? ? ? ? ?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
? ? ? ? ? ? 備注: 如果需要增加連續(xù)的天數(shù),則增加 num ?改變查詢的 開始 結(jié)束時(shí)間
? ? ? ? ? ? 例: 增加num 0 - 10000;開始時(shí)間為 2010-01-01? 結(jié)束時(shí)間為2018-12-31;
? ? ? ? ? ? 1.創(chuàng)建表方式 (臨時(shí)表 -- 只讀庫(kù)也可以創(chuàng)建)
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" --開始時(shí)間?
? ? ? ? ? ? 增加10000天。
天數(shù)連續(xù)的表有了, 在統(tǒng)計(jì)的時(shí)候就可以連續(xù)統(tǒng)計(jì)出來(lái)了。
?
?
?
另外: SUM()為空時(shí),轉(zhuǎn)為0
? ? ? ? ? ? ? ? ? ? ? COALESCE(SUM(pay_amount),0)
保留兩位小數(shù):
? ? ? ? ? ? ? ? ? ? ? ROUND(COALESCE(SUM(epc.pay_amount),0), 2)
?
?
?
?
?
?
?
?
?
?
總結(jié)
以上是生活随笔為你收集整理的SQL-按日期不间断统计的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 刚装修的房子多久能住?集成墙面真的好吗?
- 下一篇: 弘辽科技:淘宝搜索流量是什么意思?如何提