MySQL count(*)统计总数问题汇总
来源:脚本之家
时间:2022-12-31 08:58:44 368浏览 收藏
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《MySQL count(*)统计总数问题汇总》,涉及到MySQLcount、统计总数,有需要的可以收藏一下
在日常开发工作中,我经常会遇到需要统计总数的场景,比如:统计订单总数、统计用户总数等。一般我们会使用MySQL 的count函数进行统计,但是随着数据量逐渐增大,统计耗时也越来越长,最后竟然出现慢查询的情况,这究竟是什么原因呢?本篇文章带你一下学习一下。
1. MyISAM存储引擎计数为什么这么快?
我们总有个错觉,就是感觉MyISAM引擎的count计数要比InnoDB引擎更快,实际这不是错觉。
MyISAM引擎把表的总行数单独记录在磁盘上,查询的时候可以直接返回,不需要再累加统计。
但是当SQL查询中有where条件的时候,就无法再使用表的总行数了,还是需要乖乖的进行累加统计,查询性能也就跟InnoDB相差无几了。
为什么MyISAM引擎能够记录表的总行数,InnoDB引擎却不行?
因为MyISAM引擎不支持事务,只有表锁,所以记录的总行数是准确的。
而InnoDB引擎支持事务和行锁,存在并发修改的情况。又由于事务的隔离性,会出现不可重复读和幻读,记录的总行数无法保证是准确的。
2. 能不能手动实现统计总行数
既然InnoDB引擎没有帮我们记录总行数,我们能不能手动记录总行数,比如使用Redis。
其实也是不行的,使用Redis记录总行数,至少有下面3个问题:
- 无法实现事务之间的隔离
- 更新丢失,因为i++不是原子操作,当然可以使用Lua脚本实现原子操作,更复杂。
- Redis是非关系型缓存数据库,不能当作关系型持久化数据库使用,一般需要设置过期时间。
由上图中得知,虽然Redis计数加1操作放在了事务里面,但是不受事务控制的,在事务没有提交前,其他查询依然读到了最新的总行数,这就是脏读的情况。
3. InnoDB引擎能否实现快速计数
有一种办法,可以粗略估计表的总行数,就是使用MySQL命令:
show table status like 'user';
真实的总行数有100万行,预估有99万多行,误差在可接受的范围内。
部分场景适用,比如粗略估计网站的总用户数。
4. 四种计数方式的性能差别
常见的统计总行数的方式有以下四种:
count(*) 、 count(常量) 、 count(id) 、 count(字段)
InnoDB引擎对count计数做了优化,会选用数据量较小的非聚簇索引进行统计。
比如用户表中有三个索引,分别是主键索引、name索引和age索引,使用执行计划查看计数的时候用到了哪个索引?
CREATE TABLE `user` ( `id` int NOT NULL AUTO_INCREMENT COMMENT '主键', `name` varchar(100) DEFAULT NULL COMMENT '姓名', `age` tinyint NOT NULL, PRIMARY KEY (`id`), KEY `idx_name` (`name`), KEY `idx_age` (`age`) ) ENGINE=InnoDB COMMENT='用户表';
explain select count(*) from user;
用到了数据量较小的age索引。
count(*) 、 count(常量) 是直接统计表中的总行数,效率较高。
而 count(id) 还需要把数据返回给MySQL Server端进行累加计数。
最后 count(字段)需要筛选不为null字段,效率最差。
四种计数的查询性能从高到低,依次是:
count(*) ≈ count(常量) > count(id) > count(字段)
对于大多数情况,得到计数结果,还是老老实实使用count(*)
所以推荐使用select count(*),别跟**select *搞混了,不推荐使用select ***的。
本篇关于《MySQL count(*)统计总数问题汇总》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!
-
151 收藏
-
303 收藏
-
421 收藏
-
269 收藏
-
419 收藏
-
136 收藏
-
490 收藏
-
428 收藏
-
329 收藏
-
445 收藏
-
366 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 专注的白开水
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者分享文章!
- 2023-05-04 16:31:01
-
- 完美的泥猴桃
- 这篇技术文章真是及时雨啊,细节满满,受益颇多,已加入收藏夹了,关注作者了!希望作者能多写数据库相关的文章。
- 2023-04-27 17:49:07
-
- 甜蜜的手链
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢up主分享技术贴!
- 2023-04-19 21:47:46
-
- 清脆的柠檬
- 很详细,码住,感谢师傅的这篇技术贴,我会继续支持!
- 2023-04-16 21:37:24
-
- 生动的红酒
- 这篇文章太及时了,好细啊,感谢大佬分享,收藏了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-03-16 21:14:17
-
- 醉熏的水壶
- 赞 👍👍,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢老哥分享博文!
- 2023-03-12 01:54:42
-
- 爱撒娇的小笼包
- 这篇文章内容太及时了,太全面了,赞 👍👍,码住,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-02-19 11:11:50
-
- 发嗲的火车
- 这篇文章内容真是及时雨啊,太全面了,写的不错,码住,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-02-14 02:53:09
-
- 帅气的小土豆
- 太全面了,收藏了,感谢老哥的这篇文章内容,我会继续支持!
- 2023-02-03 17:59:31
-
- 开放的白昼
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者分享文章!
- 2023-01-24 08:16:22
-
- 能干的西牛
- 很详细,码起来,感谢作者的这篇技术文章,我会继续支持!
- 2023-01-22 21:34:16
-
- 斯文的书本
- 这篇技术文章真是及时雨啊,老哥加油!
- 2023-01-18 23:56:22
-
- 等待的超短裙
- 这篇技术文章真及时,太全面了,很好,收藏了,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-01-13 16:26:15
-
- 儒雅的飞机
- 这篇技术贴出现的刚刚好,好细啊,太给力了,码起来,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-01-11 13:59:29
-
- 单纯的故事
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享技术贴!
- 2023-01-10 00:48:47
-
- 活泼的红酒
- 赞 👍👍,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享文章!
- 2023-01-05 14:36:00
-
- 风中的舞蹈
- 这篇技术贴出现的刚刚好,太详细了,写的不错,已加入收藏夹了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-04 20:04:46
-
- 碧蓝的百合
- 很详细,mark,感谢up主的这篇博文,我会继续支持!
- 2023-01-01 07:16:37