【转载】MySQL count(*) count(1) count(column)区别
2024-09-02 16:29:51
MyISAM 引擎把一个表的总行数存在了磁盘上,因此执行 count(*) 的时候会直接返回这个数,效率很高
InnoDB 引擎执行 count(*) 的时候,需要把数据一行一行地从引擎里面读出来,然后累积计数
count函数
count(主键 id) ,InnoDB 引擎会遍历整张表,把每一行的 id 值都取出来,返回给 server 层。server 层拿到 id 后,判断是不可能为空的,就按行累加
count(1) ,InnoDB 引擎遍历整张表,但不取值。server 层对于返回的每一行,放一个数字“1”进去,判断是不可能为空的,按行累加。
count(字段)
1)如果这个“字段”是定义为 not null 的话,一行行地从记录里面读出这个字段,判断不能为 null,按行累加;
2)如果这个“字段”定义允许为 null,那么执行的时候,判断到有可能是 null,还要把值取出来再判断一下,不是 null 才累加。
count(*) 并不会把全部字段取出来,而是专门做了优化,不取值,按行累加。
注:
count(※) 遍历哪个索引树得到的结果逻辑上都是一样的count(※) 这样的操作,遍历哪个索引树得到的结果逻辑上都是一样的MySQL 优化器会找到最小的那棵树来遍历。在保证逻辑正确的前提下,尽量减少扫描的数据量,是数据库系统设计的通用法则之一
按照效率排序的话,count(字段)<count(主键 id)<count(1)≈count(*),所
以尽量使用 count(*)
原文链接:https://blog.csdn.net/ljjzj/article/details/89341640
最新文章
- Java的四种内部类
- 去掉tableview顶部留白
- TC SRM 593 DIV2 1000
- 程序设计入门——C语言 第4周编程练习 2 念整数(5分)
- hdu1171
- Tiny4412之C语言实现流水灯,Tiny4412裸机程序[3]
- Hadoop集群运行JNI程序
- Webbrowser中模拟连接点击(非鼠标模拟)
- linux下find命令-atime,-ctime,-mtime真正含义
- leetcode 最长连续序列 longest consecutive sequence
- 《算法4》读书笔记 1.4 - 算法分析(Analysis of Algorithm)
- Discuz更改默认搜索模块
- Android项目开发填坑记-so文件引发的攻坚战
- Linux时间子系统之(十六):clockevent
- golang的map
- 基于redis的分布式锁实现
- Webpack2学习记录-2
- Junit中AssertTrue的使用
- kafka的简单理解
- Android短轮询解决方案——CountDownTimer+Handler