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

相关推荐
重庆小透明15 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
博观而约取40 分钟前
Django 数据迁移全解析:makemigrations & migrate 常见错误与解决方案
后端·python·django
寻月隐君2 小时前
Rust 异步编程实践:从 Tokio 基础到阻塞任务处理模式
后端·rust·github
GO兔2 小时前
开篇:GORM入门——Go语言的ORM王者
开发语言·后端·golang·go
Sincerelyplz2 小时前
【Temproal】快速了解Temproal的核心概念以及使用
笔记·后端·开源
爱上语文2 小时前
Redis基础(6):SpringDataRedis
数据库·redis·后端
Lemon程序馆2 小时前
速通 GO 垃圾回收机制
后端·go
Aurora_NeAr2 小时前
Spark SQL架构及高级用法
大数据·后端·spark
杰尼橙子2 小时前
DPDK BPF:将eBPF虚拟机的灵活性带入到了DPDK的高性能用户态
后端·性能优化
代码老y2 小时前
Spring Boot + 本地部署大模型实现:优化与性能提升
java·spring boot·后端