做一个积极的人

编码、改bug、提升自己

我有一个乐园,面向编程,春暖花开!

x 可以代表: 主键id、字段、1、*

0 说明

对于count(主键id)来说

innodb引擎会遍历整张表,把每一行的id值都取出来,返回给server层,server层判断id值不为空,就按行累加

对于count(字段)来说

如果这个字段定义为not null,一行行的从记录里面读出这个字段,判断不为空,则累加值

如果这个字段定义允许为null,那么执行的时候,判断到有可能为null,还要把值取出来在判断一下,不是null才累加

对于count(1)来说

innodb引擎遍历整张表,但不取值,返回给server层,server对于返回的每一行,放一个数字1进去,判断是不可能为空的,就按行累加

对于count(*)

并不会把全部字段取出来,而是专门做了优化,不取值,count(*)肯定不是null,按行累加

1 总结

如果你要统计行数就用count(*)或者count(1),推荐前者

如果要统计某个字段不为NULL值的个数就用count(字段)

在《高性能MySQL》中有如下:

  1. 当mysql确认括号内的表达式值不可能为空时,实际上就是在统计行数

  2. 如果mysql知道某列col不可能为NULL值,那么mysql内部会将count(col)表达式优化为count(*)

也就是说count(主键字段)和count(1)还是要优化到count(*)的。

MySQL 5.7 Reference Manual的官方手册中:https://dev.mysql.com/doc/refman/5.7/en/group-by-functions.html#function_count

有这么一段:

InnoDB handles SELECT COUNT(*) and SELECT COUNT(1) operations in the same way. There is no performance difference.

翻译: InnoDB以相同的方式处理SELECT COUNT(*)和SELECT COUNT(1)操作。没有性能差异。

所以这几个按照效率排序的话,count(字段)<count(主键id)<count(1)≈count(*)

所以,尽量使用count(*)

2 拓展

在阿里巴巴的 Mysql数据库 >> ( 三) ) SQL


谢谢你的阅读,如果您觉得这篇博文对你有帮助,请点赞或者喜欢,让更多的人看到!祝你每天开心愉快!


不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!

博客首页 : https://aflyun.blog.csdn.net/

愿你我在人生的路上能都变成最好的自己,能够成为一个独挡一面的人

© 每天都在变得更好的阿飞云

更多相关文章

  1. oracle --sql--转换表字段日期格式(年月日时分秒转换年月日)
  2. MySQL字段名与保留字冲突
  3. 写SQL语句,如何找到部分字段内容一样的两条记录?实现调货的功能
  4. Mysql 修改字段类型
  5. [置顶] sql server中对日期字段值的比较
  6. Mssql根据表名获取字段
  7. 注解匹配表字段与实体字段
  8. Mysql查询时,对于数值型字段加单引号会引起的误解~
  9. 如何在Android应用里对HTTP请求头部添加适当的User-Agent字段

随机推荐

  1. Android中RadioGroup组与onCheckedChange
  2. Android Studio无法执行Java类的main方法
  3. Android 实现在Java代码中修改UI界面,并修
  4. Android API Differences Report
  5. Android ApiDemos示例解析(100):Views->A
  6. CreateProcess error=2, 系统找不到指定
  7. Android添加单元测试的方法与步骤
  8. Android SDK的docs访问速度很慢
  9. android添加超级管理权限
  10. Android环境变量作用--命令行操作