[摘要]+--------+------------+--------+1 row in set (0.31 sec)当offset很大时,会出现效率问题,随着offset的增大,执行效率下降。 分析影响...
+--------+------------+--------+1 row in set (0.31 sec)当offset很大时,会出现效率问题,随着offset的增大,执行效率下降。 分析影响性能原因因为数据表是InnoDB,根据InnoDB索引的结构,查询过程为: 通过二级索引查到主键值(找出所有gender=1的id)。 再根据查到的主键值通过主键索引找到相应的数据块(根据id找出对应的数据块内容)。 根据offset的值,查询300001次主键索引的数据,最后将之前的300000条丢弃,取出最后1条。
不过既然二级索引已经找到主键值,为什么还需要先用主键索引找到数据块,再根据offset的值做偏移处理呢? 如果在找到主键索引后,先执行offset偏移处理,跳过300000条,再通过第300001条记录的主键索引去读取数据块,这样就能提高效率了。 如果我们只查询出主键,看看有什么不同 mysql> select id from member where gender=1 limit 300000,1;
+--------+ |
关键词: 详细说明在mysql查询时 offset过大影响性能的原因与优化办法