如何使用 MySQL 统计每个监测对象的解析失败率?
不知道大家是否熟悉?今天我将给大家介绍,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!
mysql 分组统计失败率
问题:
如何在 mysql 中对表中的数据进行分组统计,计算指定字段的失败率?例如,对于一个具有以下结构的表:
create table `parse_monitoring` ( `id` int not null auto_increment, `track_source_id` int not null, `is_parsed` int not null, `parsed_at` timestamp not null default current_timestamp on update current_timestamp, primary key (`id`), key `index_parsed_at` (`parsed_at`) ) engine=innodb default charset=utf8mb4 collate=utf8mb4_0900_ai_ci;
其中:
- track_source_id 表示监测对象
- is_parsed 表示解析是否成功,0 表示失败,1 表示成功
- parsed_at 表示解析时间
给出这样的需求,统计每个 track_source_id 的解析失败率。
解答:
可以通过以下 sql 查询来实现:
SELECT track_source_id, 1 - SUM(is_parsed) / COUNT(*) FROM parse_monitoring GROUP BY track_source_id
今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注主机宝贝公众号,一起学习编程~