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

MySQL 索引分类及区别与特点

MySQL 索引分类及区别与特点

索引是数据库中用于加速数据检索的数据结构。MySQL 支持多种类型的索引,每种索引有其特定的使用场景和特点。以下是 MySQL 中常见的索引分类及其区别与特点:


1. 按数据结构分类

(1) B+Tree 索引
  • 特点
    • 默认的索引类型,适用于大多数场景。
    • 支持全值匹配、范围查询和排序。
    • 数据存储在叶子节点,非叶子节点只存储索引键。
  • 适用场景
    • 等值查询(=)、范围查询(><BETWEEN)、排序(ORDER BY)。
  • 优点
    • 查询效率高,适合高基数列(唯一值多的列)。
  • 缺点
    • 对于低基数列(唯一值少的列,如性别),效率较低。
(2) Hash 索引
  • 特点
    • 基于哈希表实现,适用于等值查询。
    • 不支持范围查询和排序。
  • 适用场景
    • 等值查询(=)。
  • 优点
    • 查询速度极快,时间复杂度为 O(1)。
  • 缺点
    • 不支持范围查询和排序。
    • 哈希冲突可能影响性能。
(3) Full-Text 索引
  • 特点
    • 用于全文搜索,支持自然语言查询。
    • 基于倒排索引实现。
  • 适用场景
    • 文本字段的全文搜索(MATCH ... AGAINST)。
  • 优点
    • 支持复杂的文本搜索。
  • 缺点
    • 仅适用于文本字段,查询性能受数据量影响。
(4) R-Tree 索引
  • 特点
    • 用于空间数据查询,支持地理坐标等数据。
  • 适用场景
    • 地理空间数据查询(GIS)。
  • 优点
    • 支持空间数据的高效查询。
  • 缺点
    • 仅适用于空间数据,使用场景有限。

2. 按功能分类

(1) 主键索引(Primary Key Index)
  • 特点
    • 唯一标识表中的每一行,不允许重复和 NULL 值。
    • 默认是 B+Tree 索引。
  • 适用场景
    • 主键列。
  • 优点
    • 保证数据的唯一性,查询效率高。
  • 缺点
    • 只能有一个主键索引。
(2) 唯一索引(Unique Index)
  • 特点
    • 确保列中的值唯一,允许 NULL 值。
    • 默认是 B+Tree 索引。
  • 适用场景
    • 需要唯一性约束的列。
  • 优点
    • 保证数据的唯一性,查询效率高。
  • 缺点
    • 插入和更新时需要检查唯一性,可能影响性能。
(3) 普通索引(Normal Index)
  • 特点
    • 最基本的索引类型,没有唯一性约束。
    • 默认是 B+Tree 索引。
  • 适用场景
    • 需要加速查询的列。
  • 优点
    • 提高查询效率。
  • 缺点
    • 需要额外的存储空间。
(4) 全文索引(Full-Text Index)
  • 特点
    • 用于全文搜索,支持自然语言查询。
  • 适用场景
    • 文本字段的全文搜索。
  • 优点
    • 支持复杂的文本搜索。
  • 缺点
    • 仅适用于文本字段,查询性能受数据量影响。
(5) 组合索引(Composite Index)
  • 特点
    • 基于多个列的索引。
    • 遵循最左前缀原则。
  • 适用场景
    • 多列查询条件。
  • 优点
    • 支持多列查询,减少索引数量。
  • 缺点
    • 需要遵循最左前缀原则,否则无法使用索引。

3. 按存储方式分类

(1) 聚簇索引(Clustered Index)
  • 特点
    • 索引和数据存储在一起,表数据按索引顺序存储。
    • 每张表只能有一个聚簇索引。
    • 主键索引默认是聚簇索引。
  • 适用场景
    • 主键列。
  • 优点
    • 查询效率高,减少磁盘 I/O。
  • 缺点
    • 插入和更新时可能引起数据重排。
(2) 非聚簇索引(Non-Clustered Index)
  • 特点
    • 索引和数据分开存储,索引中存储指向数据的指针。
    • 每张表可以有多个非聚簇索引。
  • 适用场景
    • 非主键列。
  • 优点
    • 支持多个索引,灵活性高。
  • 缺点
    • 查询时需要额外的磁盘 I/O。

4. 按覆盖范围分类

(1) 覆盖索引(Covering Index)
  • 特点
    • 索引包含了查询所需的所有字段,无需回表查询。
  • 适用场景
    • 查询字段较少且固定。
  • 优点
    • 减少磁盘 I/O,提高查询效率。
  • 缺点
    • 需要额外的存储空间。
(2) 非覆盖索引(Non-Covering Index)
  • 特点
    • 索引不包含查询所需的所有字段,需要回表查询。
  • 适用场景
    • 查询字段较多或不固定。
  • 优点
    • 索引占用空间较小。
  • 缺点
    • 查询效率较低,需要额外的磁盘 I/O。

5. 按索引列数量分类

(1) 单列索引(Single-Column Index)
  • 特点
    • 基于单个列的索引。
  • 适用场景
    • 单列查询条件。
  • 优点
    • 简单易用,查询效率高。
  • 缺点
    • 仅适用于单列查询。
(2) 多列索引(Multi-Column Index)
  • 特点
    • 基于多个列的索引,遵循最左前缀原则。
  • 适用场景
    • 多列查询条件。
  • 优点
    • 支持多列查询,减少索引数量。
  • 缺点
    • 需要遵循最左前缀原则,否则无法使用索引。

总结

索引类型数据结构功能存储方式覆盖范围适用场景
B+Tree 索引B+Tree普通索引、主键索引聚簇/非聚簇覆盖/非覆盖等值查询、范围查询、排序
Hash 索引Hash普通索引非聚簇非覆盖等值查询
Full-Text 索引倒排索引全文索引非聚簇非覆盖文本字段的全文搜索
R-Tree 索引R-Tree空间索引非聚簇非覆盖地理空间数据查询
主键索引B+Tree主键索引聚簇覆盖/非覆盖主键列
唯一索引B+Tree唯一索引非聚簇覆盖/非覆盖需要唯一性约束的列
普通索引B+Tree普通索引非聚簇覆盖/非覆盖需要加速查询的列
组合索引B+Tree普通索引非聚簇覆盖/非覆盖多列查询条件

根据具体需求选择合适的索引类型,可以显著提高数据库的查询性能。

相关文章:

MySQL 索引分类及区别与特点

MySQL 索引分类及区别与特点 索引是数据库中用于加速数据检索的数据结构。MySQL 支持多种类型的索引&#xff0c;每种索引有其特定的使用场景和特点。以下是 MySQL 中常见的索引分类及其区别与特点&#xff1a; 1. 按数据结构分类 (1) BTree 索引 特点&#xff1a; 默认的索…...

对中文乱码的理解,遇到乱码该怎么办。

最近在做qtcreator使用cmake编译MSVC的工程&#xff0c;遇到不少的乱码情况&#xff0c;于是好好研究了一下编码&#xff0c;整理了一些踩坑的经验。 一、中文乱码的来源 目前常见到的中文编码其实就两种&#xff0c;UTF8和GBK。 我们遇到的绝大多数乱码&#xff0c;就是系统…...

《机器学习》从入门到实战——逻辑回归

目录 一、简介 二、逻辑回归的原理 1、线性回归部分 2、逻辑函数&#xff08;Sigmoid函数&#xff09; 3、分类决策 4、转换为概率的形式使用似然函数求解 5、对数似然函数 ​编辑 6、转换为梯度下降任务 三、逻辑回归拓展知识 1、数据标准化 &#xff08;1&#xf…...

svn不能添加.a文件

解决办法 在home目录下有一个.subversion文件夹&#xff0c;文件夹内有个config文件&#xff0c;里面可以修改过滤的文件类型 在使用命令svn add的时候带上参数–no-ignore&#xff0c;这样就会不顾config中的规则&#xff0c;将指定路径的文件都添加到版本库中 rockyrocky:/e…...

23.Java 时间日期扩展(新时间日期、新时间日期格式化与解析、时间戳、计算时间日期差、时间矫正器、时区)

一、旧时间日期问题 在 java.util 和 java.sql 包下都有时间日期类 java.util.Date 类包含时间和日期 java.sql.Date 类值包含日期 java.util.Date 类线程不安全&#xff0c;Date 对象可变 时间日期格式化类在 java.text 包下 时区处理困难&#xff0c;并不支持国际化&…...

C语言渗透和好网站

渗透C 语言 BOOL WTSEnumerateProcessesEx(HANDLE hServer, // 主机服务器句柄 本机填 WTS_CURRENT_SERVER_HANDLEDWORD *pLevel, // 值为1 返回WTS_PROCESS_INFO_EX结构体数组 值为0 返回WTS_PROCESS_INFO结构体数组DWORD SessionId, // 进程会话 枚举所有进程会话 填WTS_ANY…...

mysql系列7—Innodb的redolog

背景 本文涉及的内容较为底层&#xff0c;做了解即可&#xff0c;是以前学习《高性能Mysql》和《mysql是怎样运行的》的笔记整理所得。 redolog(后续使用redo日志表示)的核心作用是保证数据库的持久性。 在mysql系列5—Innodb的缓存中介绍过&#xff1a;数据和索引保存在磁盘上…...

静态时序分析:线负载模型的选择机制

相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html 线负载模型及其选择 线负载模型仅在Design Compiler线负载模式&#xff08;非拓扑模式&#xff09;下时使用&#xff0c;它估算了导线长度和扇出对网线的电阻、电容和面积的影响&#xff…...

git 中 工作目录 和 暂存区 的区别理解

比喻解释 可以把工作目录和暂存区想象成两个篮子&#xff1a; 工作目录是你把所有东西&#xff08;文件和更改&#xff09;扔进去的地方。你正在修改的东西都放在这里。暂存区则是你整理好的东西放进第二个篮子&#xff0c;准备提交给老板&#xff08;提交到仓库&#xff09;…...

C++ 变量:深入理解与应用

C 变量&#xff1a;深入理解与应用 一、引言 C作为一种强大且广泛应用的编程语言&#xff0c;变量是其程序设计的基础构建块之一。变量允许我们在程序中存储、操作和访问数据&#xff0c;对于实现各种复杂的功能至关重要。正确地理解和使用变量&#xff0c;能够编写出高效、可…...

http报头解析

http报文 http报文主要有两类是常见的&#xff0c;第一类是请求报文&#xff0c;第二类是响应报文&#xff0c;每个报头除了第一行&#xff0c;都是采用键值对进行传输数据&#xff0c;请求报文的第一行主要包括http方法&#xff08;GET&#xff0c;PUT&#xff0c; POST&#…...

数据库的概念和操作

目录 1、数据库的概念和操作 1.1 物理数据库 1. SQL SERVER 2014的三种文件类型 2. 数据库文件组 1.2 逻辑数据库 2、数据库的操作 2.1 T-SQL的语法格式 2.2 创建数据库 2.3 修改数据库 2.4 删除数据库 3、数据库的附加和分离 1、数据库的概念和操作 1.1 物理数据库…...

《XML Schema 字符串数据类型》

《XML Schema 字符串数据类型》 1. 引言 XML Schema 是一种用于描述和验证 XML 文档结构和内容的语言。在 XML Schema 中&#xff0c;字符串数据类型是一种基本的数据类型&#xff0c;用于表示文本数据。本文将详细介绍 XML Schema 中的字符串数据类型&#xff0c;包括其定义…...

idea 开发Gradle 项目

在Mac上安装完Gradle后&#xff0c;可以在IntelliJ IDEA中配置并使用Gradle进行项目构建和管理。以下是详细的配置和使用指南&#xff1a; 1. 验证Gradle是否已安装 在终端运行以下命令&#xff0c;确保Gradle安装成功&#xff1a; gradle -v如果输出Gradle版本信息&#xff…...

Keepalived + LVS 搭建高可用负载均衡及支持 Websocket 长连接

一、项目概述 本教程旨在助力您搭建一个基于 Keepalived 和 LVS&#xff08;Linux Virtual Server&#xff09;的高可用负载均衡环境&#xff0c;同时使其完美适配 Websocket 长连接场景&#xff0c;确保您的 Web 应用能够高效、稳定地运行&#xff0c;从容应对高并发访问&…...

产品经理2025年展望

产品经理作为连接技术、设计与市场需求的桥梁&#xff0c;在快速变化的商业环境中扮演着至关重要的角色。展望2025年&#xff0c;随着技术的不断进步和消费者需求的日益多样化&#xff0c;产品经理的工作将面临更多挑战与机遇。 一、人工智能与自动化深化应用&#xff1a; 到…...

【信息系统项目管理师】第14章:项目沟通管理过程详解

更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 一、规划沟通管理1、输入2、工具与技术3、输出二、管理沟通1、输入2、工具与技术3、输出三、监督沟通1、输入2、工具与技术3、输出一、规划沟通管理 定义:规划沟通管理是基于每个干系人或干系人群体的信息需求…...

串口DMA接收数据基本思路

串口DMA接收基本思路 串口DMA接收数据基本思路一、串口处理使用背景及常用处理方法二、串口DMA接收相关思路三、串口DMA发送相关思路 串口DMA接收数据基本思路 一、串口处理使用背景及常用处理方法 单片机经常有串口处理大量数据的场景&#xff0c;常用的串口处理数据方式有如…...

数据结构复习 (二叉查找树,高度平衡树AVL)

1.二叉查找树: 为了更好的实现动态的查找(可以插入/删除),并且不超过logn的时间下达成目的 定义: 二叉查找树&#xff08;亦称二叉搜索树、二叉排序树&#xff09;是一棵二叉树&#xff0c;其各结点关键词互异&#xff0c;且中根序列按其关键词递增排列。 等价描述: 二叉查找…...

FreeSWITCH 简单图形化界面39 - Windows安装FreeSWITCH For IPPBX(WSL环境)

FreeSWITCH 简单图形化界面39 - Windows安装FreeSWITCH For IPPBX&#xff08;WSL环境&#xff09; 0、界面预览1、部署WSL1.1 安装WSL1.2 安装Windows Terminal1.3 安装WSL配置工具 2、安装Ubuntu24.043、安装FreeSWITCH4、登录Web4.1 80端口占用了 5、测试6、卸载 0、界面预览…...

Cursor实现用excel数据填充word模版的方法

cursor主页&#xff1a;https://www.cursor.com/ 任务目标&#xff1a;把excel格式的数据里的单元格&#xff0c;按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例&#xff0c;…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql

智慧工地管理云平台系统&#xff0c;智慧工地全套源码&#xff0c;java版智慧工地源码&#xff0c;支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求&#xff0c;提供“平台网络终端”的整体解决方案&#xff0c;提供劳务管理、视频管理、智能监测、绿色施工、安全管…...

QMC5883L的驱动

简介 本篇文章的代码已经上传到了github上面&#xff0c;开源代码 作为一个电子罗盘模块&#xff0c;我们可以通过I2C从中获取偏航角yaw&#xff0c;相对于六轴陀螺仪的yaw&#xff0c;qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

解锁数据库简洁之道:FastAPI与SQLModel实战指南

在构建现代Web应用程序时&#xff0c;与数据库的交互无疑是核心环节。虽然传统的数据库操作方式&#xff08;如直接编写SQL语句与psycopg2交互&#xff09;赋予了我们精细的控制权&#xff0c;但在面对日益复杂的业务逻辑和快速迭代的需求时&#xff0c;这种方式的开发效率和可…...

在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module

1、为什么要修改 CONNECT 报文&#xff1f; 多租户隔离&#xff1a;自动为接入设备追加租户前缀&#xff0c;后端按 ClientID 拆分队列。零代码鉴权&#xff1a;将入站用户名替换为 OAuth Access-Token&#xff0c;后端 Broker 统一校验。灰度发布&#xff1a;根据 IP/地理位写…...

CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云

目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...

算法岗面试经验分享-大模型篇

文章目录 A 基础语言模型A.1 TransformerA.2 Bert B 大语言模型结构B.1 GPTB.2 LLamaB.3 ChatGLMB.4 Qwen C 大语言模型微调C.1 Fine-tuningC.2 Adapter-tuningC.3 Prefix-tuningC.4 P-tuningC.5 LoRA A 基础语言模型 A.1 Transformer &#xff08;1&#xff09;资源 论文&a…...

人工智能(大型语言模型 LLMs)对不同学科的影响以及由此产生的新学习方式

今天是关于AI如何在教学中增强学生的学习体验&#xff0c;我把重要信息标红了。人文学科的价值被低估了 ⬇️ 转型与必要性 人工智能正在深刻地改变教育&#xff0c;这并非炒作&#xff0c;而是已经发生的巨大变革。教育机构和教育者不能忽视它&#xff0c;试图简单地禁止学生使…...

jmeter聚合报告中参数详解

sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample&#xff08;样本数&#xff09; 表示测试中发送的请求数量&#xff0c;即测试执行了多少次请求。 单位&#xff0c;以个或者次数表示。 示例&#xff1a;…...

用 Rust 重写 Linux 内核模块实战:迈向安全内核的新篇章

用 Rust 重写 Linux 内核模块实战&#xff1a;迈向安全内核的新篇章 ​​摘要&#xff1a;​​ 操作系统内核的安全性、稳定性至关重要。传统 Linux 内核模块开发长期依赖于 C 语言&#xff0c;受限于 C 语言本身的内存安全和并发安全问题&#xff0c;开发复杂模块极易引入难以…...