今天兄弟团队找到我,期望出一份他们访问中间件(飞鸽)的发布量数据,由于目前的系统报表没有细分到队列级别,一次这里做一次测试和记录。
需求
按照分钟级别统计使用组件的发布量
表结构
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进行。
这里是列表文本先对时间进行转换
为了便于阅读,先对时间进行转换
date_format( FROM_UNIXTIME(time), '%Y-%m-%d %H:%i' ) as time_test
这里是列表文本对转换后的数据进行分组
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
查询效果如下:
优缺点
优点:可以按照数据表中的数据,按照分钟级别进行统计
缺点:无法将时间进行连续的进行展示,例如某分钟没有数据,则结果中没有任何数据