今天兄弟团队找到我,指望出一份他们访问中间件(飞鸽)的发布量数据,因为目前的系统报表没有细分到队列级别,一次这里作一次测试和记录。mysql
按照分钟级别统计使用组件的发布量sql
CREATE TABLE `test` ( `id` bigint(20) NOT NULL, `content` text, `time` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `time_idx` (`time`) USING BTREE ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
id为消息id,content为消息内容,time为Unix时间戳函数
解决思路,经过mysql的时间戳函数: FROM_UNIXTIME 以及分组:group by进行。测试
为了便于阅读,先对时间进行转换code
date_format( FROM_UNIXTIME(time
), '%Y-%m-%d %H:%i' ) as time_testorm
group by time_test中间件
完整的查询语句以下:队列
SELECT date_format( FROM_UNIXTIME(`time`), '%Y-%m-%d %H:%i' ) AS time_test, count( id ) FROM `test` WHERE `time` BETWEEN 1447776000 AND 1447862400 GROUP BY time_test ORDER BY time_test
查询效果以下:图片
优势:能够按照数据表中的数据,按照分钟级别进行统计it
缺点:没法将时间进行连续的进行展现,例如某分钟没有数据,则结果中没有任何数据