日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

SQL-按日期不间断统计

發(fā)布時(shí)間:2024/1/8 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQL-按日期不间断统计 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

一、數(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。