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

最新文章

  1. Java的四种内部类
  2. 去掉tableview顶部留白
  3. TC SRM 593 DIV2 1000
  4. 程序设计入门——C语言 第4周编程练习 2 念整数(5分)
  5. hdu1171
  6. Tiny4412之C语言实现流水灯,Tiny4412裸机程序[3]
  7. Hadoop集群运行JNI程序
  8. Webbrowser中模拟连接点击(非鼠标模拟)
  9. linux下find命令-atime,-ctime,-mtime真正含义
  10. leetcode 最长连续序列 longest consecutive sequence
  11. 《算法4》读书笔记 1.4 - 算法分析(Analysis of Algorithm)
  12. Discuz更改默认搜索模块
  13. Android项目开发填坑记-so文件引发的攻坚战
  14. Linux时间子系统之(十六):clockevent
  15. golang的map
  16. 基于redis的分布式锁实现
  17. Webpack2学习记录-2
  18. Junit中AssertTrue的使用
  19. kafka的简单理解
  20. Android短轮询解决方案——CountDownTimer+Handler

热门文章

  1. txt_to_csv
  2. linux 性能测试之基准测试工具
  3. ARC101E Ribbons on Tree 容斥原理+dp
  4. CF 36E Two Paths
  5. vue中使用canvas绘制签名
  6. 【leetcode】1021. Best Sightseeing Pair
  7. Excel,此文件中的某些文本格式可能已经更改,因为它已经超出最多允许的字体数。
  8. boost tuple
  9. JS中数据结构之集合
  10. python的迭代器(转自廖雪峰老师python基础)