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

2.索引:MySQL 索引分类

MySQL中的索引是提高数据查询速度的重要工具,就像一本书的目录,可以帮助我们快速定位到所需的内容。选择适合的索引类型对数据库设计和性能优化至关重要。本文将详细介绍MySQL中常见的索引类型,并重点讲解聚集索引和二级索引的概念及应用。


1. 主键索引(Primary Key Index)
  • 概念:主键索引是唯一索引的一种,确保表中每条记录的唯一性。每张表只能有一个主键,通常在创建表时指定。

  • 特点:自动唯一,不允许空值(NULL),且主键列会自动添加一个聚集索引(在InnoDB存储引擎中)。

  • 使用场景:用作表的唯一标识,如用户表的用户ID字段,能够快速定位数据。

    示例

    CREATE TABLE users (user_id INT PRIMARY KEY,name VARCHAR(100),email VARCHAR(100)
    );
    

2. 唯一索引(Unique Index)
  • 概念:唯一索引确保索引列的所有值唯一,但允许空值(NULL)。唯一索引主要用于保证数据完整性。

  • 特点:允许列值唯一,适合有唯一性要求的数据。

  • 使用场景:如邮箱、身份证号等信息,适合使用唯一索引来防止重复。

    示例

    sql复制代码CREATE TABLE employees (emp_id INT PRIMARY KEY,emp_email VARCHAR(100) UNIQUE
    );
    

3. 普通索引(Index)
  • 概念:普通索引没有唯一性限制,可以在表的多个字段上创建,主要作用是加快查询。

  • 特点:允许重复和空值,适合搜索频繁的数据列。

  • 使用场景:比如文章的标题、内容摘要等字段的搜索。

    示例

    CREATE INDEX idx_title ON articles(title);
    

4. 全文索引(Full-Text Index)
  • 概念:用于较长文本字段的全文搜索。MySQL会通过分词来快速匹配关键词。

  • 特点:适合模糊查询。

  • 使用场景:博客文章、商品描述等长文本的关键词匹配。

    示例

    CREATE TABLE posts (id INT PRIMARY KEY,content TEXT,FULLTEXT(content)
    );
    

5. 组合索引(Composite Index)
  • 概念:包含多个列的索引,用于多列查询。MySQL会将这些列组合形成一个单一索引。

  • 特点:需遵循“最左前缀”原则。

  • 使用场景:适合多列组合查询。

    示例

    CREATE INDEX idx_country_city ON users(country, city);
    

6. 聚集索引(Clustered Index)

InnoDB 存储引擎的特有

  • 概念:聚集索引是将数据存储与索引结构结合的特殊索引类型。在InnoDB中,每张表都必须有一个聚集索引,它会将数据行存储在B+树结构中,树的叶节点包含了实际的数据行。

  • 特点:数据按照主键顺序存储在磁盘上,因此主键列就是聚集索引。每个表只能有一个聚集索引,因为数据的物理存储方式只能按一种顺序排列。

  • 使用场景:聚集索引适合需要按顺序读取的数据,比如按日期排序的日志记录。它提高了范围查询的效率,但在需要频繁更新主键列的表中应谨慎使用,因为频繁重排会影响性能。

    示例

    CREATE TABLE orders (order_id INT PRIMARY KEY,order_date DATE,customer_id INT
    );
    

    在这里,order_id作为主键将创建一个聚集索引,数据按order_id的顺序存储。


7. 二级索引(Secondary Index)

InnoDB 存储引擎的特有

  • 概念:二级索引(也称非聚集索引)是除了聚集索引之外的其他索引。它只存储索引列和指向数据行的引用(如主键值),而不直接存储数据本身。

  • 特点:二级索引的叶节点存储了键值和指向聚集索引的指针,因此当通过二级索引查找数据时,需要通过该指针找到数据行。这种方式称为“回表”操作,会稍微影响查询速度。

  • 使用场景:适合不需要顺序访问的数据列,如姓名、邮箱等字段,通过二级索引可以有效地加快查询速度。

    示例

    CREATE INDEX idx_name ON users(name);
    

    在这里,idx_name是一个二级索引,通过用户的姓名来加速查询,但它需要回表找到实际数据行。


8. 索引总结图:

索引的具体类型主要分为以下几类:主键索引、唯一索引、常规索引、全文索引。

分类含义特点关键字
主键索引针对于表中主键创建的索引默认自动创建,只能有一个PRIMARY
唯一索引避免同一个表中某数据列中的值重复可以有多个UNIQUE
常规索引快速定位特定数据可以有多个
全文索引全文索引查找的是文本中的关键词,而不是比较索引中的值可以有多个FULLTEXT

InnoDB存储引擎中,根据索引的存储形式,又可以分为以下两种:

分类含义特点
聚集索引 (Clustered Index)将数据存储与索引放到了一块,索引结构的叶子节点保存了行数据必须有,而且只有一个
二级索引 (Secondary Index)将数据与索引分开存储,索引结构的叶子节点关联的是对应的主键可以存在多个

对应B+Tree图:
在这里插入图片描述

9. 总结

在MySQL中,聚集索引与二级索引的搭配使用能更好地平衡数据访问性能。聚集索引适合数据量大且有顺序需求的场景,而二级索引则适合独立的数据列搜索。根据实际应用场景选择合适的索引,不仅能提升查询效率,也能确保数据库的高效运行。希望这篇文章帮助您更好地理解MySQL中的索引类型及其使用场景!

http://www.lryc.cn/news/480023.html

相关文章:

  • sklearn红酒数据集分类器的构建和评估
  • 【IC验证面试常问-4】
  • 【数据集】【YOLO】【目标检测】交通事故识别数据集 8939 张,YOLO道路事故目标检测实战训练教程!
  • 书生浦语第四期基础岛L1G4000-InternLM + LlamaIndex RAG 实践
  • 基于ViT的无监督工业异常检测模型汇总
  • 数据库管理-第258期 23ai:Oracle Data Redaction(20241104)
  • 运放进阶篇-多种波形可调信号发生器-产生方波-三角波-正弦波
  • CSS中的变量应用——:root,Sass变量,JavaScript中使用Sass变量
  • WPF+MVVM案例实战与特效(二十八)- 自定义WPF ComboBox样式:打造个性化下拉菜单
  • 速盾:怎么使用cdn加速?
  • C++ 优先算法 —— 三数之和(双指针)
  • YOLOv7-0.1部分代码阅读笔记-yolo.py
  • 【缓存与加速技术实践】Web缓存代理与CDN内容分发网络
  • MySQL的约束和三大范式
  • Unity网络通信(part7.分包和黏包)
  • 练习题 - DRF 3.x Overviewses 框架概述
  • Linux 经典面试八股文
  • Filter和Listener
  • Go 项目中实现类似 Java Shiro 的权限控制中间件?
  • 【Javascript】-一些原生的网页设计案例
  • SpringBoot开发——Spring Boot 3种定时任务方式
  • Flutter鸿蒙next 实现长按录音按钮及动画特效
  • 【计网】实现reactor反应堆模型 --- 框架搭建
  • 力扣中等难度热题——长度为K的子数组的能量值
  • JSON格式
  • O-RAN前传Spilt Option 7-2x
  • 【GeoJSON在线编辑平台】(2)吸附+删除+挖孔+扩展
  • 确定图像的熵和各向异性 Halcon entropy_gray 解析
  • 大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels
  • 算法通关(3) -- kmp算法