MySQL 的存储引擎有哪些?它们之间有什么区别? MySQL InnoDB 引擎中的聚簇索引和非聚簇索引有什么区别? MySQL 的索引类型有哪些?
MySQL 的存储引擎有哪些?它们之间有什么区别?
先来回顾以下我们业务场景下一般的数据库访问的过程应用——>server层 ——>存储引擎层——>磁盘

https://i-blog.csdnimg.cn/direct/cdc2786ac8d54e57869281702d70cacf.png)](https://i-blog.csdnimg.cn/direct/02b72ec2b8274186ae5f2c5401f25f83.png)
官网描述:
InnoDB: MySQL 8.4 中的默认存储引擎。 InnoDB 是事务安全(符合 ACID) 存储引擎,具有 commit、rollback 和 崩溃恢复功能来保护用户数据。 InnoDB 行级锁定(无升级 到更粗粒度的锁)和 Oracle 样式一致 非锁定读取增加了多用户并发性,并且 性能。 InnoDB 将用户数据存储在 聚集索引,用于减少基于的常见查询的 I/O 主键。为了维护数据完整性, InnoDB 还支持 FOREIGN KEY 引用完整性约束。
MyISAM: 这些表占用空间小。 表级锁定 限制了读/写工作负载的性能,因此它通常是 用于 Web 和数据中的只读或只读工作负载 仓储配置。
Memory: 将所有数据存储在 RAM 中,以便在 需要快速查找非关键数据。这个引擎是以前称为 HEAP 发动机。它的用途案例正在减少; InnoDB 及其缓冲区 池内存区域提供了一种通用且持久的方式 将大部分或全部数据保留在内存中,以及 NDBCLUSTER 提供快速的键值查找 用于大型分布式数据集。
总结: 节选自面试鸭 作者:木子金又二丨




MySQL InnoDB 引擎中的聚簇索引和非聚簇索引有什么区别?
同问方式
什么是聚集索引,什么是二级索引(非聚集索引)
什么是回表?

聚集索引的选取规则:
1.如果存在主键,主键就是一个聚集索引。
2.如果不存在主键,将使用第一个唯一(UNIQUE)索引作为聚集索引。
3.如果表没有主键,或没有合适的唯一索引,则InnoDB会自动生成一个rowid作为隐藏的聚集索引。

总结:
聚簇索引(聚集索引):数据与索引放到一块,B+树的叶子节点保存了整行数据,有且只有一个。
非聚簇索引(二级索引):数据与索引分开存储,B+树的叶子节点保存对应的主键,可以有多个。
回表查询:通过二级索引找到对应的主键值,到聚集索引中查找整行数据,这个过程就是回表
MySQL 的索引类型有哪些?
一、按 数据结构 分类
- B+Tree 索引
- 特点:MySQL 默认的索引结构,支持范围查询和排序,适用于大部分场景。
- 适用场景:
=,>,<,BETWEEN,ORDER BY等操作。 - 支持引擎:InnoDB、MyISAM、Memory 等。
- Hash 索引
- 特点:基于哈希表实现,仅支持精确匹配(等值查询),查询速度快,但不支持范围查询和排序。
- 适用场景:等值查询(如
WHERE key = value)。 - 支持引擎:Memory 引擎显式支持,InnoDB 支持自适应哈希索引(内部自动管理,用户无法手动创建)。
- 全文索引(Full-Text)
- 特点:针对文本内容分词检索,支持自然语言搜索和关键词匹配。
- 适用场景:大文本字段(如
CHAR、VARCHAR、TEXT)的全文搜索。 - 支持引擎:MyISAM 和 InnoDB(MySQL 5.6+)。
- 空间索引(R-Tree)
- 特点:用于地理空间数据类型(如
GEOMETRY、POINT、POLYGON),支持空间关系计算。 - 适用场景:地理数据查询(如距离计算、区域覆盖)。
- 支持引擎:MyISAM(早期)和 InnoDB(MySQL 5.7+)。
- 特点:用于地理空间数据类型(如
二、按 逻辑功能 分类
- 主键索引(Primary Key)
- 特点:唯一且非空,每个表只能有一个主键索引。
- 数据结构:InnoDB 中主键索引是聚簇索引(数据与索引存储在一起)。
- 唯一索引(Unique Key)
- 特点:确保列值唯一,允许 NULL 值(但 NULL 可重复)。
- 数据结构:B+Tree。
- 普通索引(Normal Index)
- 特点:最基本的索引,无唯一性约束,仅加速查询。
- 数据结构:B+Tree。
- 组合索引(Composite Index)
- 特点:多个列组合成的索引,遵循 最左前缀原则。
- 示例:索引
(a, b, c)可支持WHERE a=1、WHERE a=1 AND b=2,但不支持WHERE b=2。
- 前缀索引(Prefix Index)
- 特点:对长文本字段的前 N 个字符建立索引,节省存储空间。
- 语法:
CREATE INDEX idx_name ON table (column(N))。
- 覆盖索引(Covering Index)
- 特点:查询的列全部包含在索引中,无需回表查询数据行。
- 优化点:显著减少 I/O 操作,提升查询性能。
三、其他特殊索引
- 自适应哈希索引(Adaptive Hash Index)
- 特点:InnoDB 自动为频繁访问的索引页创建哈希索引,用户不可控。
- 作用:加速等值查询。
- 倒排索引(Inverted Index)
- 特点:全文索引的底层实现,通过分词建立词条到文档的映射。
四、存储引擎对索引的支持
| 索引类型 | InnoDB | MyISAM | Memory |
|---|---|---|---|
| B+Tree | ✅ | ✅ | ✅ |
| Hash | ❌(仅自适应) | ❌ | ✅ |
| 全文索引(FULLTEXT) | ✅(5.6+) | ✅ | ❌ |
| 空间索引(R-Tree) | ✅(5.7+) | ✅ | ❌ |
五、选择索引的建议
- 高频查询字段:优先考虑使用索引。
- 区分度高:选择区分度高的列(如用户ID)建立索引。
- 避免冗余:合理设计组合索引,避免单列重复索引。
- 更新代价:索引会降低写操作速度,需权衡读写比例。
查询字段**:优先考虑使用索引。 - 区分度高:选择区分度高的列(如用户ID)建立索引。
- 避免冗余:合理设计组合索引,避免单列重复索引。
- 更新代价:索引会降低写操作速度,需权衡读写比例。
相关文章:
MySQL 的存储引擎有哪些?它们之间有什么区别? MySQL InnoDB 引擎中的聚簇索引和非聚簇索引有什么区别? MySQL 的索引类型有哪些?
MySQL 的存储引擎有哪些?它们之间有什么区别? 先来回顾以下我们业务场景下一般的数据库访问的过程应用——>server层 ——>存储引擎层——>磁盘 官网描述: InnoDB: MySQL 8.4 中的默认存储引擎。 InnoDB 是事务安全(符…...
【Linux探索学习】第二十六弹——进程通信:深入理解Linux中的进程通信
Linux探索学习: https://blog.csdn.net/2301_80220607/category_12805278.html?spm1001.2014.3001.5482 前言: 在Linux操作系统中,进程通信(IPC)是操作系统的一项核心功能,用于在不同进程之间交换数据或…...
netcore https配置
一、生成证书 1. 安装 OpenSSL 如果尚未安装 OpenSSL,可以通过以下命令安装:Ubuntu/Debian:sudo apt update sudo apt install openssl CentOS/RHEL:sudo yum install openssl 2. 生成私钥 使用以下命令生成私钥文件(private.key)…...
遥感影像目标检测:从CNN(Faster-RCNN)到Transformer(DETR)
我国高分辨率对地观测系统重大专项已全面启动,高空间、高光谱、高时间分辨率和宽地面覆盖于一体的全球天空地一体化立体对地观测网逐步形成,将成为保障国家安全的基础性和战略性资源。未来10年全球每天获取的观测数据将超过10PB,遥感大数据时…...
rtcwake - Linux下定时唤醒计算机
rtcwake 是一个用于通过实时时钟(RTC)唤醒计算机的工具。它常用于在 Linux 系统中设置计算机在指定时间自动唤醒或关闭。以下是对命令 rtcwake -m off -s ${sleep_time} 的详细解析: 命令解析 bash复制 rtcwake -m off -s ${sleep_time} 1…...
使用vscode调试transformers源码
简要介绍如何使用vscode调试transformers源码 以源码的方式安装transformers(官方手册为Editable install) 优先参考官方手册 git clone https://github.com/huggingface/transformers.git cd transformers pip install -e .以下展示transformers/exa…...
LeetCode39
LeetCode39 目录 题目描述示例思路分析代码段代码逐行讲解复杂度分析总结的知识点整合总结 题目描述 给定一个无重复元素的整数数组 candidates 和一个目标整数 target,找出 candidates 中所有可以使数字和为 target 的组合。candidates 中的数字可以无限制重复选…...
sql not in 优化
sql优化 1、not in 的优化 not in和not exists不会命中索引,可以优化为通过left join实现; 例如要查询存在于a表但不存在与b表的数据,比较容易理解的sql写法: SELECT * FROM table_a WHERE id NOT IN (SELECT aid FROM table_b)…...
同花顺C++面试题及参考答案
对 C 和 C++ 哪个更熟悉? 在编程语言的学习与实践中,我对 C++ 更为熟悉。C 语言作为一门经典的编程语言,以其高效、灵活和接近硬件的特性,在系统编程、嵌入式开发等领域占据着重要地位。它提供了丰富的底层操作能力,如指针操作、内存管理等,为开发者直接控制计算机资源提…...
PostgreSQL 添加索引导致崩溃,参数调整需谨慎--文档未必完全覆盖场景
开头还是介绍一下群,如果感兴趣PolarDB ,MongoDB ,MySQL ,PostgreSQL ,Redis, OceanBase, Sql Server等有问题,有需求都可以加群群内有各大数据库行业大咖,可以解决你的问题。加群请联系 liuaustin3 ,(共2720人左右 1 …...
【Linux Redis】关于用docker拉取Redis后,让虚拟机运行起来redis,并使得其可以连接到虚拟机外的navicat。
步骤一:拉取Redis镜像 docker pull redis 这个命令会下载最新版本的Redis镜像到你的本地Docker仓库中。你也可以指定一个具体的版本号,例如docker pull redis:6.2.6,来拉取特定版本的Redis镜像。 如果拉取遇到问题请参考【Linux AnolisOS】关…...
Python常见面试题的详解8
1. 变量作用域和查找规则(LEGB) 作用域层级: Local:函数内部作用域 Enclosing:闭包函数外层作用域 Global:模块全局作用域 Built-in:内置命名空间 查找顺序:L → E → G → B关…...
【含文档+PPT+源码】基于微信小程序的校园志愿者管理系统的设计与实现
项目介绍 本课程演示的是一款 基于微信小程序的校园志愿者管理系统的设计与实现,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含:项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本…...
LED灯闪烁实验:实验介绍
文章目录 1 实验目标2 工具链2.1 硬件2.2 软件 3 实验流程 1 实验目标 本实验结合Matlab/Simulink工具链和STM工具链,实现STM32开发板上的LED灯闪烁功能。 2 工具链 2.1 硬件 STM32F103C8T6最小系统板 STM32F103C8T6最小系统板是基于STM32F103C8T6微控制器的开发…...
亲测Windows部署Ollama+WebUI可视化
一. Ollama下载 登录Ollama官网(Ollama)点击Download进行下载 如果下载很慢可用以下地址下载: https://github.com/ollama/ollama/releases/download/v0.5.7/OllamaSetup.exe 在DeepSeek官网上,你可以直接点击【model】 到达这个界面之后,…...
代码随想录-- 第一天图论 --- 岛屿的数量
99 统计岛屿的数量 c 99. 岛屿数量 #include <iostream> #include <vector> #include <queue>using namespace std;struct MGraph {int numVertices, numEdges;vector<vector<int>> Edge; };int dir[4][2] {{1, 0}, {0, 1}, {-1, 0}, {0, -1}…...
Docker 部署 Nacos (图文并茂超详细)
部署 Nacos ( Docker ) [Step 1] : 拉取 Nacos 镜像 docker pull nacos/nacos-server:v2.1.1[Step 2] : 创建目录 ➡️ 创建容器 ➡️ 拷贝文件 ➡️ 授权文件 ➡️ 删除容器 # 创建目录 mkdir -p /data/nacos/{conf,logs,data}# 创建容器 docker run -p 8848:8848 --name …...
petalinux高版本设置自动登录和开机自启动配置
petalinux-config -c rootfs 依次选择 Image Features -> serial-autologin-root 这是配置 进来就是root权限 创建并安装名为 myapp-init 的新建应用程序 petalinux-create -t apps --template install -n myapp-init --enable 编辑 project-spec/meta-user/recipes-…...
MySQL 的存储引擎简介
使用show engines可以查看安装的MySQL的引擎相关信息 MySQL 的引擎不止这么多,这只是安装的这个版本有的引擎。可以看到,只有 InnoDB 支持事务,其他的引擎都是不支持事务的。 说几个我了解的比较多的引擎: InnoDB InnoDB 是MyS…...
《Operating System Concepts》阅读笔记:p34-p40
《Operating System Concepts》学习第 7 天,p34-p40 总结,总计 7 页。 一、技术总结 1.virtualization(虚拟化) (1)定义 A technology for abstracting the hardware of a single computer into several different execution environments, thereby …...
嵌入式0xDEADBEEF
在嵌入式系统中,0xDEADBEEF 是一个常见的“魔数”(magic number),通常用于调试和内存管理。它的含义和用途如下: 1. 调试用途 未初始化内存的标记:在调试时,0xDEADBEEF 常用于标记未初始化或已…...
“深入浅出”系列之QT:(10)Qt接入Deepseek
项目配置: 在.pro文件中添加网络模块: QT core network API配置: 将apiUrl替换为实际的DeepSeek API端点 将apiKey替换为你的有效API密钥 根据API文档调整请求参数(模型名称、温度值等) 功能说明: 使…...
php文件包含
文章目录 基础概念php伪协议什么是协议协议的格式php中的协议file协议http协议ftp协议php://input协议php://filter协议php://data协议 php文件上传机制高级文件包含nginx文件日志包含临时文件包含session文件包含pear文件包含远程文件包含 基础概念 文件包含,相当…...
第四天面试题
文章目录 1.什么叫 Java 的内存泄露与内存溢出?**1. 内存泄露(Memory Leak)****内存泄露的常见原因:****如何避免内存泄露:** **2. 内存溢出(Out Of Memory, OOM)****内存溢出的常见原因&#x…...
网络技术变迁:从IPv4走向IPv6
目录 前言 旧时代产物:IPv4 什么是IPv4? IPv4的工作方式 IPv4的缺点 为什么要从IPv4过渡到IPv6? 走向IPv6:新一代互联网协议 IPv6的技术特性 我们需要过渡技术 双栈(Dual Stack) 隧道技术&#…...
突破反爬困境:从服务端渲染到客户端SPA,爬虫环境的演变与新挑战(一)
声明 本文所讨论的内容及技术均纯属学术交流与技术研究目的,旨在探讨和总结互联网数据流动、前后端技术架构及安全防御中的技术演进。文中提及的各类技术手段和策略均仅供技术人员在合法与合规的前提下进行研究、学习与防御测试之用。 作者不支持亦不鼓励任何未经授…...
ElasticSearch映射分词
目录 弃用Type why 映射 查询 mapping of index 创建 index with mapping 添加 field with mapping 数据迁移 1.新建 一个 index with correct mapping 2.数据迁移 reindex data into that index 分词 POST _analyze 自定义词库 ik分词器 circuit_breaking_excep…...
Vue.js 配置 Babel、Webpack 和 ESLint
Vue.js 配置 Babel、Webpack 和 ESLint 今天我们来聊聊如何配置 Babel、Webpack 和 ESLint,这三个工具在现代前端开发中扮演着重要角色。它们分别负责代码转译、模块打包和代码质量检测,合理配置它们能大大提高项目的开发效率和质量。下面我将详细介绍它…...
Es的text和keyword类型以及如何修改类型
昨天同事触发定时任务发现es相关服务报了一个序列化问题, 今天早上捕获异常将异常堆栈全部打出来看,才发现是聚合的字段不是keyword类型的问题。 到kibbna命令行执行也是一样的错误 使用 /_mapping查看索引的字段类型,才发现userUniqueid是te…...
1-18 GIT设置公钥
1-1 GIT如何设置公钥 1.0 注册账号 这个应该都是会的,就不做介绍了 2.0 设置公钥 PWD的作用是查看文件的路径 ssh-keygen -t ed25519 -C "Gitee SSH Key" 读取公钥文件: cat ~/.ssh/id_ed25519.pub 3.0 测试 查看绑定的用户名和邮箱࿱…...
