mysql处理请求时间和请求量_MySQL按照分钟统计请求量

今天兄弟团队找到我,期望出一份他们访问中间件(飞鸽)的发布量数据,由于目前的系统报表没有细分到队列级别,一次这里做一次测试和记录。

需求

按照分钟级别统计使用组件的发布量

表结构

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

查询效果如下:

0818b9ca8b590ca3270a3433284dd417.png

优缺点

优点:可以按照数据表中的数据,按照分钟级别进行统计

缺点:无法将时间进行连续的进行展示,例如某分钟没有数据,则结果中没有任何数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值