【MySQL】count统计哪种更快
目录
一. MySQL 的逻辑架构图
二. 对比各种count方法(以Innodb为例)
1.count(*)
a). InnoDB存储引擎遍历整张表,但不取值。server 层对于返回的每一行,不判断是否为空,直接按行累加。
2. count(1)
a). InnoDB存储引擎遍历整张表,但不取值。server 层对于返回的每一行,放一个数字"1"进去,判断是否为空(值不会为空,但逻辑如此),不为空则按行累加。
3.count(主键)
a). InnoDB存储引擎会遍历整张表,把每一行的【主键值】取出来,返回给 server 层。server 层拿到【主键值】后,判断是否为空(主键不会为空,但逻辑如此),不为空则按行累加。
b). 返回【主键值】,会涉及解析行数据以及拷贝字段值的操作
4. count(字段)
a). 字段不可空(Not Null):InnoDB存储引擎会遍历整张表,把每一行的【字段值】取出来,返回给 server 层。server 层拿到【字段值】后,按行累加。
b). 字段可空(Null):InnoDB存储引擎会遍历整张表,把每一行的【字段值】取出来,返回给 server 层。server 层拿到【字段值】后,判断是否为空,不为空则按行累加。
c). 返回字段值,会涉及解析行数据以及拷贝字段值的操作
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
2015-01-10 项目中存在的问题
2011-01-10 C#操作SQLite 报错 (Attempt to write a read-only database)