常用索引有哪些?联合索引使用时要注意什么?什么是最左匹配原则?联合索引(a, b, c),使用(b, c) 可以命中索引吗?(a, c) 呢?


1. 常用索引有哪些?

回答:

常用的索引主要包括以下几种:

  • 主键索引(Primary Key Index):唯一且非空的索引,通常用于标识表中的每一行数据。
  • 唯一索引(Unique Index):保证索引列的值唯一,但允许为空。
  • 普通索引(Normal Index):最基本的索引类型,用于加速查询,无唯一性约束。
  • 联合索引(Composite Index):由多个列组合而成,用于优化多条件查询。
  • 全文索引(Full-Text Index):用于文本搜索,常见于需要模糊匹配的场景(如 MySQL 的 InnoDB 或 MyISAM)。
  • 覆盖索引(Covering Index):一种特殊情况,指查询的所有字段都包含在索引中,无需回表。

复盘:

这个回答基本覆盖了常见的索引类型。如果面试官期待更深入的内容,可以补充一些数据库引擎特定的索引(如 B+ 树索引、哈希索引)或场景化的例子(如空间索引用于地理数据)。


2. 联合索引使用时要注意什么?

回答:

使用联合索引时需要注意以下几点:

  • 字段顺序:联合索引的字段顺序会影响其使用效率,查询条件应尽量遵循最左匹配原则。
  • 选择性:优先将区分度高的字段放在前面(如性别字段区分度低,不适合放首位)。
  • 查询条件:WHERE、JOIN、ORDER BY 等语句中涉及的字段应尽量与联合索引匹配,否则可能无法命中。
  • 覆盖索引:如果查询的字段都在索引中,可以避免回表,提升性能。
  • 冗余索引:避免创建重复或冗余的联合索引,增加维护成本。

复盘:

回答中提到了一些关键点,但可以更具体。例如,可以补充"索引维护会增加写操作的开销"或"避免在频繁更新的表上滥用联合索引"。如果面试官关注细节,可以举例说明选择性对性能的影响。


3. 什么是最左匹配原则?

回答:

最左匹配原则是指在使用联合索引时,查询条件必须从索引的最左边字段开始匹配,且不能跳过中间的字段。

例如,对于联合索引 (a, b, c)

  • 查询条件 WHERE a = 1WHERE a = 1 AND b = 2 可以命中索引。
  • WHERE b = 2WHERE c = 3 无法命中,因为没有从最左字段 a 开始。
    这是因为数据库底层(如 B+ 树)按索引字段顺序组织数据,跳过左侧字段会导致无法定位索引。

复盘:

这个回答解释了最左匹配的核心逻辑,并给出了例子。如果面试官追问,可以补充"最左匹配是基于索引的物理结构决定的",或者提到"范围查询(如 a > 1)可能会影响后续字段的匹配"。


4. 联合索引 (a, b, c),使用 (b, c) 可以命中索引吗?(a, c) 呢?

回答:

  • 使用 (b, c) :无法命中索引。因为根据最左匹配原则,联合索引 (a, b, c) 要求查询从 a 开始,而 (b, c) 跳过了 a,所以不会使用该索引。
  • 使用 (a, c) :可以部分命中索引。查询会利用 a 字段的索引,但 c 无法直接命中,因为中间的 b 被跳过了。数据库可能会用 a 定位后再回表或扫描剩余条件。

复盘:

回答准确地应用了最左匹配原则。如果面试官进一步提问,可以补充"具体命中情况还需看执行计划(EXPLAIN)"或"如果查询字段都在索引中,(a, c) 可能通过覆盖索引优化"。还可以提到优化建议,如调整索引为 (a, c, b) 以适配特定查询。

相关推荐
Asthenia04128 分钟前
深入SpringBoot启动流程:自动配置与Bean生命周期核心解析
后端
豌豆花下猫11 分钟前
Python 潮流周刊#95:像人类一样使用计算机(摘要)
后端·python·ai
王达舒19941 小时前
Spring Boot中定时任务Cron表达式的终极指南
java·spring boot·后端
demonlg01121 小时前
Go 语言标准库中Channels,Goroutines详细功能介绍与示例
开发语言·后端·golang
王强你强1 小时前
Spring Boot 启动参数终极解析:如何优雅地控制你的应用?
java·spring boot·后端
vener_1 小时前
基于Flask的通用登录注册模块,并代理跳转到目标网址
后端·python·flask
Asthenia04121 小时前
git的回退:revert还是reset?来个例子看看吧!
后端
Asthenia04122 小时前
接口速度太慢,排除DB影响,试试通过异步来优化吧!
后端
Asthenia04122 小时前
Lombok注解详解:从朴素构造到高效开发
后端
杨凯凡2 小时前
Apache Shiro 全面指南:从入门到高级应用
java·后端·shiro