格式 | 描述 |
---|---|
%a | 縮寫(xiě)星期名 |
%b | 縮寫(xiě)月名 |
%c | 月,數(shù)值 |
%D | 帶有英文前綴的月中的天 |
%d | 月的天,數(shù)值(00-31) |
%e | 月的天,數(shù)值(0-31) |
%f | 微秒 |
%H | 小時(shí) (00-23) |
%h | 小時(shí) (01-12) |
%I | 小時(shí) (01-12) |
%i | 分鐘,數(shù)值(00-59) |
%j | 年的天 (001-366) |
%k | 小時(shí) (0-23) |
%l | 小時(shí) (1-12) |
%M | 月名 |
%m | 月,數(shù)值(00-12) |
%p | AM 或 PM |
%r | 時(shí)間,12-小時(shí)(hh:mm:ss AM 或 PM) |
%S | 秒(00-59) |
%s | 秒(00-59) |
%T | 時(shí)間, 24-小時(shí) (hh:mm:ss) |
%U | 周 (00-53) 星期日是一周的第一天 |
%u | 周 (00-53) 星期一是一周的第一天 |
%V | 周 (01-53) 星期日是一周的第一天,與 %X 使用 |
%v | 周 (01-53) 星期一是一周的第一天,與 %x 使用 |
%W | 星期名 |
%w | 周的天 (0=星期日, 6=星期六) |
%X | 年,其中的星期日是周的第一天,4 位,與 %V 使用 |
%x | 年,其中的星期一是周的第一天,4 位,與 %v 使用 |
%Y | 年,4 位 |
%y | 年,2 位 |
注:當(dāng)涉及到按日統(tǒng)計(jì)是,需要使用%j,而如果使用%d, %e, %w的話(huà),那么不同月份/周里的相同值會(huì)統(tǒng)計(jì)在一起。
涉及到獲取當(dāng)前時(shí)間,則可以通過(guò)now()或者sysdate()來(lái)獲取。
SELECT SYSDATE() FROM DUAL; SELECT NOW() FROM DUAL;
按照實(shí)際需求使用group by查詢(xún)即可。
結(jié)論
需統(tǒng)計(jì)的表結(jié)構(gòu)如下:
CREATE TABLE `apilog` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(64) DEFAULT NULL, `action` varchar(64) DEFAULT NULL, `params` text, `result` text, `timestamp` datetime DEFAULT NULL, PRIMARY KEY (`id`) )
統(tǒng)計(jì)時(shí)間范圍內(nèi)不同分類(lèi)action的數(shù)量
# 當(dāng)日 SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%j') = DATE_FORMAT(now(),'%j') ORDER BY count desc; # 當(dāng)周 SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%u') = DATE_FORMAT(now(),'%u') ORDER BY count desc; # 當(dāng)月 SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%m') = DATE_FORMAT(now(),'%m') ORDER BY count desc; # 當(dāng)年 SELECT action, COUNT(id) count FROM apilog WHERE DATE_FORMAT(`timestamp`,'%Y') = DATE_FORMAT(now(),'%Y') ORDER BY count desc;
統(tǒng)計(jì)某分類(lèi)action的時(shí)間維度數(shù)量
# 按日 SELECT action, DATE_FORMAT(`timestamp`,'%j'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%j') # 按周 SELECT action, DATE_FORMAT(`timestamp`,'%u'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%u') # 按月 SELECT action, DATE_FORMAT(`timestamp`,'%m'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%m') # 按年 SELECT action, DATE_FORMAT(`timestamp`,'%Y'), COUNT(id) count FROM apilog WHERE action = 'xxx' GROUP BY DATE_FORMAT(`timestamp`,'%Y')
同時(shí)按action和時(shí)間維度統(tǒng)計(jì)
# 按日 SELECT action, DATE_FORMAT(`timestamp`,'%j'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%j') # 按周 SELECT action, DATE_FORMAT(`timestamp`,'%u'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%u') # 按月 SELECT action, DATE_FORMAT(`timestamp`,'%m'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%m') # 按年 SELECT action, DATE_FORMAT(`timestamp`,'%Y'), COUNT(id) count FROM apilog GROUP BY action, DATE_FORMAT(`timestamp`,'%Y')
以上就是比較常用的時(shí)間統(tǒng)計(jì)了,更多的時(shí)間維度,可以參考上面的參數(shù)表類(lèi)似處理即可。
標(biāo)簽:???/a> 吐魯番 甘南 拉薩 洛陽(yáng) 葫蘆島 嘉峪關(guān) 安徽
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL按時(shí)間統(tǒng)計(jì)數(shù)據(jù)的方法總結(jié)》,本文關(guān)鍵詞 MySQL,按,時(shí)間,統(tǒng)計(jì)數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。