当前位置: 首页 > news >正文

MySQL索引类型

MySQL 中常见的索引类型可以从多个角度划分,面试和实战中常考的是 按数据结构分类 和 按功能/逻辑分类。下面给你一个清晰、系统的整理。

一、按数据结构分类(最核心)

索引类型 说明 适用场景

B+Tree 索引 MySQL 默认索引结构,InnoDB 主要使用 等值查询、范围查询、排序、分组

Hash 索引 基于哈希表,等值查询极快 Memory 引擎常用,不支持范围查询

R-Tree 索引 空间索引,用于地理数据 GIS 地理位置

Full-text 索引 全文索引 文本内容搜索

✅ InnoDB 默认使用 B+Tree

二、按逻辑/功能分类(最常被问)

1️⃣ 普通索引(INDEX)

• 最基本的索引

• 无唯一性限制
CREATE INDEX idx_name ON user(name);

2️⃣ 唯一索引(UNIQUE INDEX)

• 索引列值必须唯一

• 允许 NULL(多个 NULL 不算重复)
CREATE UNIQUE INDEX uk_email ON user(email);

✅ 常用于:邮箱、手机号、业务唯一键

3️⃣ 主键索引(PRIMARY KEY)

• 特殊的唯一索引

• 不允许 NULL

• 一张表只能有一个主键
PRIMARY KEY (id)

✅ InnoDB 中主键即聚簇索引

4️⃣ 组合索引(复合索引 / 联合索引)

• 多个列组成的索引

• 遵循 最左前缀原则
CREATE INDEX idx_a_b ON t(a, b);

✅ 适合多条件查询
❌ (b) 单独查询无法使用该索引

5️⃣ 前缀索引

• 对字段前 N 个字符建索引

• 节省空间
CREATE INDEX idx_title ON article(title(20));

✅ 常用于 TEXT / VARCHAR
❌ 不能用前缀索引做覆盖索引

6️⃣ 全文索引(FULLTEXT)

• 用于关键词搜索

• 替代 LIKE ‘%xxx%’
CREATE FULLTEXT INDEX ft_content ON article(content);

✅ 支持自然语言 / 布尔搜索

三、按存储方式分类(InnoDB 特有)

1️⃣ 聚簇索引(Clustered Index)

• InnoDB 主键索引

• 数据行存储在叶子节点

• 一张表只有一个

✅ 主键查询最快
❌ 主键应尽量短、自增

2️⃣ 非聚簇索引(Secondary Index)

• 普通索引、唯一索引、组合索引

• 叶子节点存 主键值

✅ 需要回表查询完整数据

四、特殊索引类型

类型 说明

覆盖索引 索引包含查询所需全部字段,无需回表

函数索引 MySQL 8.0 支持对表达式建索引

降序索引 MySQL 8.0 支持 DESC

– MySQL 8.0
CREATE INDEX idx_time ON log(create_time DESC);

五、索引类型对比总结

类型 是否默认 是否唯一 是否聚簇

PRIMARY KEY ✅ ✅ ✅

UNIQUE ❌ ✅ ❌

INDEX ❌ ❌ ❌

FULLTEXT ❌ ❌ ❌

六、面试高频一句话总结 ✅

MySQL 默认使用 B+Tree 索引,InnoDB 中主键是聚簇索引,普通索引是非聚簇索引;常见类型包括普通索引、唯一索引、主键索引、组合索引和全文索引。

http://www.jsqmd.com/news/901440/

相关文章:

  • 2026年5月天津国际学校推荐:五大专业评测择校对比案例适用场景 - 品牌推荐
  • 从‘自信满满’到‘谦虚谨慎’:实战指南教你用CalibratedClassifierCV校准SVC和朴素贝叶斯的预测概率
  • 2026年 镀锡钢板厂家推荐排行榜:宝钢/武钢新日铁/梅钢源头工厂实力与品质深度解析 - 品牌企业推荐师(官方)
  • CH582 USB开发避坑指南:用CherryUSB搞定CDC/HID设备(附完整代码)
  • 构建自评估RAG系统:从检索到生成的置信度全链路优化
  • STM32F4开发中SD卡挂载Hard Fault问题解析
  • 数据管道优化:提升数据处理效率和可靠性
  • 2026年5月北京定制游旅行社推荐:TOP5专业评测纯玩无购性价比高注意事项 - 品牌推荐
  • 巨有科技县区级旅游大数据方案|数据治旅,破解县域文旅粗放运营难题
  • 基于 CleanMark AI 项目的Flutter + HarmonyOS 完整实战教程大纲
  • 手把手教你给Pspice for TI添加Cadence自带库(解决模型缺失报错)
  • 怎么选天津国际学校?2026年5月推荐TOP5口碑评测国际部课程市场份额 - 品牌推荐
  • 基于LangChain构建端到端智能语义搜索应用:从原理到实践
  • 开源:AI 工程从零开始:435 课、20 个阶段、~320 小时,把 AI 学透
  • 基于LLM的智能招聘系统:从关键词匹配到语义理解的工程实践
  • 别再傻傻分不清!CAN总线标准帧与扩展帧的实战选择指南(附报文ID优先级详解)
  • 2026年除油精炼剂厂家推荐榜单:纺织用/环保型/高浓缩精炼剂,APG系列与腰果酚类优质品牌深度解析! - 品牌企业推荐师(官方)
  • 别再死记硬背SMO公式了!用Python手写一个简化版,带你搞懂支持向量机的核心优化
  • Dreamweaver CS6 零基础入门:从创建第一个HTML文件到发布网页的保姆级指南
  • Elasticsearch:使用预计算上下文降低 agent 成本
  • 第六感 qw咬住减少cd wCD时间
  • 【昇腾CANN】GE图引擎架构原理:让模型跑得快的隐形引擎
  • 保姆级教程:用Python从Waymo Open Dataset里提取3D点云和标签(附完整代码)
  • 告别时序图恐惧症:手把手教你用C语言实现IIC通信(附完整代码)
  • 开发者如何运用设计思维与创新方法解决技术难题
  • 从电机到屏幕:用STM32CubeMX+编码器+OLED,做个实时转速显示的小项目
  • 直流微电网并联变换器环流抑制:自适应下垂控制原理与工程实践
  • 2025-2026年变频器风机品牌推荐:TOP5评测市场份额防高温案例价格 - 品牌推荐
  • 别只当它是个编辑器:挖掘Dreamweaver CS6里那些被遗忘的‘高级’功能(AP Div与行为篇)
  • AI应用开发新范式:从直觉驱动到评估驱动开发(EDD)