MySQL中count(1),count(*),count(col)的区别

count(*)返回行数的时候不管列中的值是不是null,在MyISAM表中,count(*)被优化,因为在MyISAM表中,行数被额外存储了,所以会很快,但是这个时候不能有where条件。innodb不会做类似的优化,因为在进行事务管理的时候,并发事务可能会看到不同的列值。

在MyISAM表中,如果第一列不是null值,那么count(1)被做了和count(*)一样的优化,count(col)就是根据列名检索非null的行,如果MyISAM知道col列非null,则count(col)会被优化成count(*)。

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

原文地址:https://www.cnblogs.com/zhangcaiwang/p/7299970.html