对于辅助索引来说,我们需要查询的字段是辅助索引的字段,在辅助索引找到对应的主键(放到buffer中),然后将主键进行排序。根据排序后的主键去查询磁盘表,这样
通过将随机IO变成顺序IO来减少磁盘IO的次数。
对于MyISAM也是这样的原则,首先根据数据行的id对得到索引字段字段进行排序,而非主键,这是MyISAM和InnoDB的区别导致的。
使用场景:
对于InnoDB和MyISAM来说,主要用于索引范围扫描和表的等连接操作。
当然,对于覆盖索引,若要查询的字段在索引里,无需查询磁盘表时,就不必进行此优化。