用 count(*)哪个存储引擎会更快?

用 count(*)哪个存储引擎会更快?_第1张图片

InnoDB 引擎执行 count 函数的时候,需要通过遍历的方式来统计记录个数,而 MyISAM 引擎执行 count 函数只需要 0(1 )复杂度,这是因为每张 MyISAM 的数据表都有一个 meta 信息有存储了row_count值,由表级锁保证一致性,所以直接读取row_count 值就是 count 函数的执行结果

而 InnoDB 存储引擎是支持事务的,同一个时刻的多个查询,由于多版本并发控制(MVCC)的原因,InnoDB 表”应该返回多少行“也是不确定的,所以无法像 MyISAM一样,只维护一个 row_count 变量。

如果查询语句没有 where 查询条件的话,用 MyISAM 引擎会比较快因为 MyISAM 引擎的每张表会用一个变量存储表的总记录个数,执行 count 函数的时候,直接读这个变量就行了,而 InnoDB 引擎执行 count 函数的时候,需要通过遍历的方式来统计记录个数。

如果查询语句有 where 查询条件的话,MyISAM 和 InnoDB 引擎执行 count 函数的时候,性能都差不多,都需要根据查询条件一行行的进行统计。

你可能感兴趣的:(MySQL,数据库,java,mysql)