转自:http://blog.youkuaiyun.com/gtuu0123/article/details/5473045
1.myisam保存表的总行数,因此count(*)并且无where子句,很快会返回表的总行数
2.myisam保存表的总行数,利用count(column)并且无where子句,并且此column不为null,很快会返回表的总行数
3.myisam保存表的总行数,利用count(column)并且无where子句,并且此column可以为null,mysql会对表进行全表或全索引扫描来确定行数
4.innodb查询count(*),count(column(not null)),count(column(may be null))并且无where子句,mysql会对表进行全表或全索引扫描来确定行数
5.myisam和innodb查询count(*),count(column(not null)),count(column(may be null))并且存在where子句,mysql会对表进行索引扫描(如果列上有索引),速度也比较快
本文对比了MySQL中MyISAM与InnoDB存储引擎在不同情况下使用COUNT(*)和COUNT(column)的操作效率,包括是否存在WHERE子句、列是否允许为空等场景。
2622

被折叠的 条评论
为什么被折叠?



