码迷,mamicode.com
首页 > 数据库 > 详细

Innodb引擎中Count(*)

时间:2018-09-25 01:08:44      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:通过   数据   方法   指定   myisam   建议   索引   ODB   count   

select count(*)是MySQL中用于统计记录行数最常用的方法,count方法可以返回表内精确的行数。

在某些索引下是好事,但是如果表中有主键,count(*)的速度就会很慢,特别在千万记录以上的大表。

所以、如果是用Innodb引擎的时候,使用select count(*)语句时,建议采用二级索引速度会比用主键索引更快。

在InnoDB引擎中,当我们通过二级索引统计数据的时候,无需扫描数据文件(二级索引存储指定字段的索引,实际的指向位置是主键索引。);而通过主键索引统计数据时,由于主键索引与数据文件存放在一起,所以每次都会扫描数据文件,所以主键索引统计没有二级索引效率高。

而myisam是不同的,Myisam内置了一个计数器,所以在使用 select count(*) from table 的时候,直接可以从计数器中取出数据。

所以,在myisam引擎执行count(*)速度非常快,而且执行速度与记录条数无关,而innodb却不是这样。

 

Innodb引擎中Count(*)

标签:通过   数据   方法   指定   myisam   建议   索引   ODB   count   

原文地址:https://www.cnblogs.com/yswyzh/p/9697330.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!