理解myisam和innodb中count(*)的区别

发布时间:2020-12-11编辑:脚本学堂
介绍下mysql中myisam与innodb存储引擎中,使用count(*)查询数据时的一些区别。有需要的朋友,参考下吧。

有关mysqlinnodbmyisam引擎,在使用count(*)时的一些区别:
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会对表进行索引扫描(如果列上有索引),速度也比较
快。