常用索引有哪些?联合索引使用时要注意什么?什么是最左匹配原则?联合索引(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) 以适配特定查询。

相关推荐
点光5 小时前
使用Sentinel作为Spring Boot应用限流组件
后端
不要秃头啊5 小时前
别再谈提效了:AI 时代的开发范式本质变了
前端·后端·程序员
有志6 小时前
Java 项目添加慢 SQL 查询工具实践
后端
山佳的山6 小时前
KingbaseES 共享锁(SHARE)与排他锁(EXCLUSIVE)详解及测试复现
后端
Leo8996 小时前
rust 从零单排 之 一战到底
后端
程序员清风7 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
鱼人8 小时前
MySQL 实战入门:从“增删改查”到“高效查询”的核心指南
后端
大鹏19888 小时前
告别 Session:Spring Boot 实现 JWT 无状态登录认证全攻略
后端
Java编程爱好者8 小时前
从 AQS 到 ReentrantLock:搞懂同步队列与条件队列,这一篇就够了
后端
鱼人8 小时前
Nginx 全能指南:从反向代理到负载均衡,一篇打通任督二脉
后端