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

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.kler.cn/a/390712.html

相关文章:

  • 系统上线后发现bug,如何回退版本?已经产生的新业务数据怎么办?
  • 设计模式:工厂方法模式和策略模式
  • 【2024最新】基于springboot+vue的闲一品交易平台lw+ppt
  • 超市里的货物架调整(算法解析)|豆包MarsCode AI刷题
  • Hadoop(环境搭建篇)
  • 10款PDF翻译工具的探索之旅:我的使用经历与工具特色!!
  • html简单实现音乐播放
  • 一文了解什么是腾讯云开发
  • 使用 Visual Studio Installer 彻底卸载 Visual Studio方法与下载
  • Linux内核编程(二十)RTC子系统一驱动rx8010
  • LeetCode 3.无重复字符的最长子串
  • Oracle 外键
  • 关于倍速播放百度网盘视频
  • 区块链革命:引领数字经济新纪元的创新引擎
  • 电子产品平整无瑕,玛哈特矫平机提升用户体验
  • 电信数据清洗案例:利用MapReduce实现高效数据预处理
  • 英语阅读做题思路从何而来?
  • 【MySQL】数据库知识突破:数据类型全解析与详解
  • 5G时代的关键元件:射频微波MLCCs市场前景广阔
  • 云ECS服务器:哈尔滨三级等保的云计算解决方案
  • ubuntu ros 解决建完图后 保存的地图非常小的问题
  • C++builder中的人工智能(10)神经网络中的Sigmoid函数
  • 萤石设备视频接入平台EasyCVR海康私有化视频平台监控硬盘和普通硬盘有何区别?
  • 【详细】如何优雅地删除 Docker 容器与镜像
  • 基于构件的软件开发、软件维护、区块链技术及湖仓一体架构的应用
  • 招聘程序员