有关mysql中innodb与myisam引擎,在使用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会对表进行索引扫描(如果列上有索引),速度也比较
快。