亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MYSQL每隔10分鐘進行分組統計的實現方法

2024-07-24 13:11:33
字體:
來源:轉載
供稿:網友

前言

本文的內容主要是介紹了MYSQL每隔10分鐘進行分組統計的實現方法,在畫用戶登錄、操作情況在一天內的分布圖時會非常有用,之前我只知道用「存儲過程」實現的方法(雖然執行速度快,但真的是太不靈活了),后來學會了用高級點的「group by」方法來靈活實現類似功能。

正文:

-- time_str '2016-11-20 04:31:11'-- date_str 20161120select concat(left(date_format(time_str, '%y-%m-%d %h:%i'),15),'0') as time_flag, count(*) as count from `security`.`cmd_info` where `date_str`=20161120 group by time_flag order by time_flag; -- 127 rowsselect round(unix_timestamp(time_str)/(10 * 60)) as timekey, count(*) from `security`.`cmd_info` where `date_str`=20161120 group by timekey order by timekey; -- 126 rows-- 以上2個SQL語句的思路類似——使用「group by」進行區分,但是方法有所不同,前者只能針對10分鐘(或1小時)級別,后者可以動態調整間隔大小,兩者效率差不多,可以根據實際情況選用select concat(date(time_str),' ',hour(time_str),':',round(minute(time_str)/10,0)*10), count(*) from `security`.`cmd_info` where `date_str`=20161120 group by date(time_str), hour(time_str), round(minute(time_str)/10,0)*10; -- 145 rowsselect concat(date(time_str),' ',hour(time_str),':',floor(minute(time_str)/10)*10), count(*) from `security`.`cmd_info` where `date_str`=20161120 group by date(time_str), hour(time_str), floor(minute(time_str)/10)*10; -- 127 rows (和 date_format 那個等價)select concat(date(time_str),' ',hour(time_str),':',ceil(minute(time_str)/10)*10), count(*) from `security`.`cmd_info` where `date_str`=20161120 group by date(time_str), hour(time_str), ceil(minute(time_str)/10)*10; -- 151 rows

&

DELIMITER //DROP PROCEDURE IF EXISTS `usp_cmd_info`;CREATE PROCEDURE `usp_cmd_info`(IN dates VARCHAR(12))BEGIN SELECT count(*) from `cmd_info` where `time_str` BETWEEN CONCAT(dates, " 00:00:00") AND CONCAT(dates, " 00:10:00") INTO @count_0; SELECT count(*) from `cmd_info` where `time_str` BETWEEN CONCAT(dates, " 00:10:00") AND CONCAT(dates, " 00:20:00") INTO @count_1; ... SELECT count(*) from `cmd_info` where `time_str` BETWEEN CONCAT(dates, " 23:40:00") AND CONCAT(dates, " 23:50:00") INTO @count_142; SELECT count(*) from `cmd_info` where `time_str` BETWEEN CONCAT(dates, " 23:50:00") AND CONCAT(dates, " 23:59:59") INTO @count_143; select @count_0, @count_1, @count_2, @count_3, @count_4, @count_5, @count_6, @count_7, @count_8, @count_9, @count_10, @count_11, @count_12, @count_13, @count_14, @count_15, @count_16, @count_17, @count_18, @count_19, @count_20, @count_21, @count_22, @count_23, @count_24, @count_25, @count_26, @count_27, @count_28, @count_29, @count_30, @count_31, @count_32, @count_33, @count_34, @count_35, @count_36, @count_37, @count_38, @count_39, @count_40, @count_41, @count_42, @count_43, @count_44, @count_45, @count_46, @count_47, @count_48, @count_49, @count_50, @count_51, @count_52, @count_53, @count_54, @count_55, @count_56, @count_57, @count_58, @count_59, @count_60, @count_61, @count_62, @count_63, @count_64, @count_65, @count_66, @count_67, @count_68, @count_69, @count_70, @count_71, @count_72, @count_73, @count_74, @count_75, @count_76, @count_77, @count_78, @count_79, @count_80, @count_81, @count_82, @count_83, @count_84, @count_85, @count_86, @count_87, @count_88, @count_89, @count_90, @count_91, @count_92, @count_93, @count_94, @count_95, @count_96, @count_97, @count_98, @count_99, @count_100, @count_101, @count_102, @count_103, @count_104, @count_105, @count_106, @count_107, @count_108, @count_109, @count_110, @count_111, @count_112, @count_113, @count_114, @count_115, @count_116, @count_117, @count_118, @count_119, @count_120, @count_121, @count_122, @count_123, @count_124, @count_125, @count_126, @count_127, @count_128, @count_129, @count_130, @count_131, @count_132, @count_133, @count_134, @count_135, @count_136, @count_137, @count_138, @count_139, @count_140, @count_141, @count_142, @count_143;END //DELIMITER ;show PROCEDURE status/GCALL usp_cmd_info("2016-10-20");

上面的這段MySQL存儲過程的語句非常長,不可能用手工輸入,可以用下面的這段Python代碼按所需的時間間隔自動生成:

import datetimetoday = datetime.date.today()# 或 由給定格式字符串轉換成# today = datetime.datetime.strptime('2016-11-21', '%Y-%m-%d')min_today_time = datetime.datetime.combine(today, datetime.time.min) # 2016-11-21 00:00:00max_today_time = datetime.datetime.combine(today, datetime.time.max) # 2016-11-21 23:59:59sql_procedure_arr = []sql_procedure_arr2 = []for x in xrange(0, 60*24/5, 1):  start_datetime = min_today_time + datetime.timedelta(minutes = 5*x)  end_datetime = min_today_time + datetime.timedelta(minutes = 5*(x+1))  # print x, start_datetime.strftime("%Y-%m-%d %H:%M:%S"), end_datetime.strftime("%Y-%m-%d %H:%M:%S")  select_str = 'SELECT count(*) from `cmd_info` where `time_str` BETWEEN "{0}" AND "{1}" INTO @count_{2};'.format(start_datetime, end_datetime, x)  # print select_str  sql_procedure_arr.append(select_str)  sql_procedure_arr2.append('@count_{0}'.format(x))print '/n'.join(sql_procedure_arr)print 'select {0};'.format(', '.join(sql_procedure_arr2))

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美色图片| 亚洲电影免费观看高清完整版| 国产又爽又黄的激情精品视频| 久久影视电视剧凤归四时歌| 91嫩草在线视频| 黄色成人av在线| 国产成人在线精品| 伊人伊成久久人综合网小说| 欧美精品videossex性护士| 日韩大片免费观看视频播放| 中文字幕不卡在线视频极品| 欧美极品美女电影一区| 久久精品国产精品| 91精品国产99| 亚洲第一网站免费视频| 在线观看日韩www视频免费| 91精品在线看| 成人妇女免费播放久久久| 久久精品久久久久久| 国产精品视频色| 2019中文在线观看| 欧美有码在线观看| 欧美亚洲国产精品| 午夜精品免费视频| 91久热免费在线视频| 欧美视频国产精品| 成人中文字幕+乱码+中文字幕| 欧美激情视频一区二区| 亚洲人高潮女人毛茸茸| 国产欧美日韩中文| 国产精品久久久久久久久免费看| 色哟哟亚洲精品一区二区| 伊人久久大香线蕉av一区二区| 日韩高清欧美高清| 亚洲香蕉成人av网站在线观看| 欧美第一黄色网| 国产成人精品免费视频| 国产精品27p| 欧美日韩不卡合集视频| 在线看国产精品| 欧美有码在线观看视频| 性欧美xxxx视频在线观看| 亚洲综合自拍一区| 日本久久久久久| 成人在线激情视频| 亚洲一级片在线看| 国产啪精品视频| 日韩在线免费高清视频| 欧美wwwxxxx| 亚洲综合中文字幕68页| 国产成人精品在线播放| 亚洲成人久久电影| 国产精品福利片| 欧美日韩国产一中文字不卡| 欧美成人中文字幕在线| 97av在线视频免费播放| 欧美成人午夜激情视频| 91精品在线播放| 欧美日韩中国免费专区在线看| 欧美美女18p| 永久555www成人免费| 欧洲精品在线视频| 欧美精品在线极品| 国产91成人在在线播放| 这里只有精品在线观看| 国产成人综合一区二区三区| 国产精品自产拍高潮在线观看| 欧美性xxxx极品hd满灌| 国产一区二区三区丝袜| 亚洲人a成www在线影院| 成人做爽爽免费视频| 亚洲最新中文字幕| 国产亚洲精品久久久久久777| 久久色免费在线视频| 日韩激情视频在线| 久久最新资源网| 亚洲欧美激情精品一区二区| 精品亚洲夜色av98在线观看| 亚洲在线第一页| 日韩av一区二区在线观看| 日韩av在线免费观看| 中文日韩电影网站| 国产精品一区二区三区久久久| 色哟哟网站入口亚洲精品| 亚洲新中文字幕| 不卡在线观看电视剧完整版| 久久久国产精品视频| 91情侣偷在线精品国产| 中文国产亚洲喷潮| 国产91精品青草社区| 自拍亚洲一区欧美另类| 久久国产精品免费视频| 久久夜精品香蕉| 国产精品自拍偷拍视频| 精品国产一区二区三区久久| 亚洲网在线观看| 91精品国产高清久久久久久久久| 国产亚洲在线播放| 久久久久国产精品免费网站| 亚洲在线www| 91a在线视频| 亚洲人成亚洲人成在线观看| 欧美巨猛xxxx猛交黑人97人| 亚洲成人av片在线观看| 亚洲精品国产品国语在线| 日韩av资源在线播放| 国产精品美女呻吟| 热久久这里只有| 欧美激情视频播放| 成人在线国产精品| 久久久久久久999精品视频| 国产欧美精品日韩精品| 欧美日韩亚洲高清| 中文国产亚洲喷潮| 国产精品一区二区三区久久| 国产精品亚洲自拍| 成人激情黄色网| 亚洲人成绝费网站色www| 欧美性xxxx在线播放| 538国产精品一区二区免费视频| 北条麻妃一区二区三区中文字幕| 久久亚洲精品小早川怜子66| 亚洲精品国产综合区久久久久久久| 国产一区二区香蕉| 91精品国产99久久久久久| 久久久久久一区二区三区| 亚洲国产99精品国自产| 日韩国产欧美区| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美韩日一区二区| 成人国产精品日本在线| 欧美精品久久久久| 久久欧美在线电影| 亚洲天堂男人天堂| 国产日产亚洲精品| 日韩一区在线视频| 欧美精品电影免费在线观看| 欧美国产日韩一区二区| 欧美精品激情在线| 欧美日韩在线视频一区| 欧美日韩激情小视频| 欧美激情免费看| 国产婷婷97碰碰久久人人蜜臀| 中文字幕久久精品| 亚洲大尺度美女在线| 国产精品久久久av| 国产精品一区二区在线| 久久久久这里只有精品| 国产91在线播放| 欧美日韩国产成人| 久久这里只有精品视频首页| 黑人巨大精品欧美一区二区一视频| 亚洲性生活视频| 久久99精品视频一区97| 久久国产精品电影| 欧美视频免费在线| 欧美性猛交xxxx免费看| 色偷偷av一区二区三区| 国产一区二区黄| 高清欧美性猛交xxxx| 国产日韩欧美自拍| 精品中文字幕在线| 国产成人精品视频在线观看| 欧美成人高清视频|