MySQL圖表數(shù)據(jù)統(tǒng)計(jì)常用方法

常用時(shí)間函數(shù)

NOW()當(dāng)前時(shí)間芳绩、CURDATE()當(dāng)前日期、CURTIME()當(dāng)前時(shí)間

SELECT NOW(),CURDATE(),CURTIME();
>2019-03-22 10:20:13 
>2019-03-22
>10:20:13

ROUND() 四舍五入
FROM_UNIXTIME() 將時(shí)間戳格式化(10位時(shí)間戳,精確到秒)

若數(shù)據(jù)庫(kù)存的時(shí)間戳為13位(精確到毫秒)盹兢,因MySQL只能轉(zhuǎn)10位砂轻,則進(jìn)行轉(zhuǎn)換
SELECT FROM_UNIXTIME(ROUND(1552665572000/1000));
>2019-03-15 23:59:32

DATE_FORMAT() 格式化時(shí)間

SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s');
>2019-03-22 09:58:50

DATE_SUB() 日期減去指定的時(shí)間間隔 (DATE_ADD()同理)

DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(時(shí)間字段名) 近7天
type常用參數(shù):DAY、MONTH然爆、YEAR站粟、HOUR

常用判空函數(shù)

IFNULL(fieldA,fieldB)
當(dāng)字段fieldA是NULL時(shí)取fieldB,不是NULL時(shí)取fieldA的值
COALESCE (exp,value1,value2……,valuen)
exp為待檢測(cè)的表達(dá)式曾雕,返回包括exp在內(nèi)的所有參數(shù)中的第一個(gè)非空表達(dá)式

SELECT IFNULL(b.count,0),COALESCE(c.sum,0) FROM ...
常用與于統(tǒng)計(jì)總數(shù)時(shí)對(duì)null值賦0的作用

MySQL常見(jiàn)JOIN語(yǔ)法

SELECT ... FROM table1 xxx JOIN table2 ON ...

INNER JOIN(內(nèi)連接):取得兩個(gè)表中存在連接匹配關(guān)系的記錄奴烙。

inner join.png

LEFT JOIN(左連接):取得左表(table1)完全記錄,即是右表(table2)并無(wú)對(duì)應(yīng)匹配記錄翻默。
left join.png

RIGHT JOIN(右連接):與 LEFT JOIN 相反缸沃,取得右表(table2)完全記錄,即是左表(table1)并無(wú)匹配對(duì)應(yīng)記錄修械。
right join.png

注:MySQL不支持FULL JOIN,不過(guò)可以通過(guò)UNION 關(guān)鍵字來(lái)合并 LEFT JOIN 與 RIGHT JOIN來(lái)模擬FULL JOIN

UNION

SELECT ... FROM ... UNION SELECT ... FROM ...
對(duì)結(jié)果集取并集操作趾牧,不包括重復(fù)行,同時(shí)進(jìn)行默認(rèn)規(guī)則的排序
去重且排序

UNION ALL

SELECT  FROM ... UNION ALL SELECT ... FROM ...
對(duì)結(jié)果集取并集操作肯污,包括重復(fù)行翘单,不進(jìn)行排序
不去重不排序

折線圖統(tǒng)計(jì)一段時(shí)間沒(méi)有數(shù)據(jù)補(bǔ)0的情況

構(gòu)建一個(gè)虛擬的最近日期記錄吨枉,如:
統(tǒng)計(jì)最近三天

SELECT CURDATE() AS time
UNION ALL
SELECT DATE_SUB(CURDATE(), interval 1 DAY) AS time
UNION ALL
SELECT DATE_SUB(CURDATE(), interval 2 DAY) AS time

統(tǒng)計(jì)最近三月

SELECT DATE_FORMAT(CURDATE(), '%Y-%m') AS time
UNION ALL
SELECT DATE_FORMAT(DATE_SUB(CURDATE(), interval 1 MONTH), '%Y-%m') AS time
UNION ALL
SELECT DATE_FORMAT(DATE_SUB(CURDATE(), interval 2 MONTH), '%Y-%m') AS time

統(tǒng)計(jì)最近三小時(shí)

SELECT DATE_FORMAT(NOW(), '%m-%d %H') as time 
UNION ALL 
SELECT DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 1 HOUR), '%m-%d %H') AS time
UNION ALL 
SELECT DATE_FORMAT(DATE_SUB(NOW(), INTERVAL 2 HOUR), '%m-%d %H') AS time

或利用mysql自帶數(shù)據(jù)庫(kù)生成數(shù)據(jù),如生成最近7天日期列表

SELECT @s :=@s + 1 as `index`, DATE(DATE_SUB(CURRENT_DATE, INTERVAL @s DAY)) AS `date`
FROM mysql.help_topic,(SELECT @s := -1) temp
WHERE @s < 6
ORDER BY `date` DESC

最后將以上數(shù)據(jù)與業(yè)務(wù)數(shù)據(jù)取左連接LEFT JOIN即可哄芜。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末貌亭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子认臊,更是在濱河造成了極大的恐慌圃庭,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件失晴,死亡現(xiàn)場(chǎng)離奇詭異剧腻,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)涂屁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)书在,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人拆又,你說(shuō)我怎么就攤上這事儒旬。” “怎么了帖族?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵栈源,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我盟萨,道長(zhǎng)凉翻,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任捻激,我火速辦了婚禮制轰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胞谭。我一直安慰自己垃杖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布丈屹。 她就那樣靜靜地躺著调俘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪旺垒。 梳的紋絲不亂的頭發(fā)上彩库,一...
    開(kāi)封第一講書(shū)人閱讀 50,050評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音先蒋,去河邊找鬼骇钦。 笑死,一個(gè)胖子當(dāng)著我的面吹牛竞漾,可吹牛的內(nèi)容都是我干的眯搭。 我是一名探鬼主播窥翩,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼鳞仙!你這毒婦竟也來(lái)了寇蚊?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤棍好,失蹤者是張志新(化名)和其女友劉穎仗岸,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體借笙,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡爹梁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了提澎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡念链,死狀恐怖盼忌,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情掂墓,我是刑警寧澤谦纱,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站君编,受9級(jí)特大地震影響跨嘉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吃嘿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一祠乃、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧兑燥,春花似錦亮瓷、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至挣饥,卻和暖如春除师,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扔枫。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工汛聚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人茧吊。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓贞岭,卻偏偏與公主長(zhǎng)得像八毯,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瞄桨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351