覆盖索引
索引上的数据可以直接提供查询结果,不需要回表,索引已经“覆盖了”查询的需求,这就叫做覆盖索引。
优点:覆盖索引减少了树的搜索次数,可以显著提升查询性能。
最左前缀
建立了联合索引(a,b),由于满足了最左前缀原则,所以相当于也建立了索引(a)
问题:在建立联合索引的时候,如何安排索引内的字段顺序?
第一原则是,如果通过调整顺序,可以少维护一个索引,那么这个顺序往往就是需要优先考虑采用的;其次考虑的原则是空间。
举例一:需要建立(a,b)和(b)的索引,由于可以调整联合索引的顺序为(b,a),相当于就也建立了索引(b),所以直接建立联合索引(b,a)即可。
举例二:需要建立(a,b)和(a)和(b)的索引,有2种索引建立办法 (b,a)和(a) 或 (a,b)和(b) 。两种办法效果是一样的,这个时候就可以考虑空间的问题,如果字段a的长度远小于字段b,那么就可以采用 (b,a)和(a) 的索引建立办法。
索引下推
在MySQL 5.6之后,引入了索引下推的优化,可以在索引的遍历过程中,对索引中包含的字段先行进行判断,过滤掉不满足条件的记录,减少回表次数。
举例:有联合索引(name,age),查询条件where name like '张%' and age=10
无索引下推
有索引下推
通过图片可以看出,索引下推减少了回表的次数,所以可以提升查询性能。