数据库索引种类

文章目录

  • 索引的优缺点
    • 优点
    • 缺点
  • 聚簇索引
    • 特点
    • 优点
    • 缺点
  • 非聚簇索引
    • 特点
    • 优点
    • 缺点
    • 使用场景:
  • 在MyISAM与InnoDB中的使用

索引的优缺点

索引概述
MySQL官方将索引定义为帮助MySQL高效获取数据的数据结构。索引的本质是一种排好序的快速查找数据结构,用于满足特定查找算法。这些数据结构指向数据,允许实现高级查找算法。

优点

索引带来多个优点:

  1. 提高数据检索效率,降低数据库的IO成本,类似于大学图书馆的书目索引,是主要创建索引的原因。
  2. 创建唯一索引可以确保数据库表中每一行数据的唯一性
  3. 有助于实现数据参考完整性,可以加速表和表之间的连接,尤其在有依赖关系的子表和父表联合查询时,可以提高查询速度。
  4. 在使用分组和排序子句进行数据查询时,可以显著减少查询中分组和排序的时间,降低CPU的消耗。

缺点

增加索引也伴随着一些不利的方面:

  1. 创建和维护索引需要耗费时间,随着数据量的增加,所需时间也会增加。
  2. 索引需要占用磁盘空间,除了数据表占用的数据空间之外,每个索引还需要一定的物理空间,存储在磁盘上。如果有大量的索引,索引文件可能会比数据文件更快达到最大文件尺寸。
  3. 尽管索引大大提高了查询速度,却会降低更新表的速度。当对表中的数据进行增加、删除和修改时,索引也需要动态地维护,从而降低了数据的维护速度。

因此,在选择是否使用索引时,需要综合考虑索引的优点和缺点。’

聚簇索引

特点

聚簇索引(Clustered Index)具有以下特点:

  1. 物理存储顺序: 聚簇索引决定了数据行在表中的物理存储顺序。数据行按照聚簇索引的键值顺序在磁盘上连续存储,这有助于减少磁盘I/O操作,提高查询性能。

  2. 唯一性要求: 聚簇索引要求键值是唯一的,因为它确定了数据行的物理存储顺序。通常,表的主键列用于创建聚簇索引,以确保数据行的唯一性。

  3. 主键索引: 聚簇索引通常与表的主键相关联。主键是表的唯一标识符,使用聚簇索引对主键列进行快速查找非常有效。

  4. 只有一个聚簇索引: 通常情况下,每张表只能有一个聚簇索引,因为数据行的物理存储顺序只能有一个。这与非聚簇索引不同,一张表可以有多个非聚簇索引。

  5. 使用记录主键值的大小进行记录和页的排序,这包括三个方面的含义:

    • 页内 的记录是按照主键的大小顺序排成一个 单向链表
    • 各个存放 用户记录的页 也是根据页中用户记录的主键大小顺序排成一个 双向链表
    • 存放 目录项记录的页 分为不同的层次,在同一层次中的页也是根据页中目录项记录的主键
      大小顺序排成一个 双向链表 。
  6. B+树的叶子节点存储的是完整的用户记录

    • 所谓完整的用户记录,就是指这个记录中存储了所有列的值(包括隐藏列)。

优点

  • 数据访问更快 ,因为聚簇索引将索引和数据保存在同一个B+树中,因此从聚簇索引中获取数据比非聚簇索引更快
  • 聚簇索引对于主键的 排序查找范围查找 速度非常快
  • 按照聚簇索引排列顺序,查询显示一定范围数据的时候,由于数据都是紧密相连,数据库不用从多个数据块中提取数据,所以 节省了大量的io操作 。

缺点

  • 插入速度严重依赖于插入顺序 ,按照主键的顺序插入是最快的方式,否则将会出现页分裂,严重影响性能。因此,对于InnoDB表,我们一般都会定义一个自增的ID列为主键
  • 更新主键的代价很高 ,因为将会导致被更新的行移动。因此,对于InnoDB表,我们一般定义主键为不可更新
  • 二级索引访问需要两次索引查找 ,第一次找到主键值,第二次根据主键值找到行数据。

非聚簇索引

特点

  • 非聚簇索引不改变数据表的物理顺序,而是在索引中维护了数据行的引用。
  • 每张表可以有多个非聚簇索引,每个非聚簇索引都有自己的独立存储结构。
  • 非聚簇索引通常包括索引键和指向数据行的指针或物理地址。(Best important)
  • 非聚簇索引的构建和维护会增加存储空间和维护成本,但提供了更快的读取性能。

优点

  • 提高检索性能:非聚簇索引允许快速查找和过滤数据,因为它们提供了索引键的有序列表,减少了需要扫描整个表的需求。
  • 支持覆盖索引:非聚簇索引可以覆盖查询的所有列,从而避免了对实际数据行的访问,进一步提高查询性能。
  • 支持多个索引:可以在同一表上创建多个非聚簇索引,以满足不同查询的需求。

缺点

  • 额外存储开销:每个非聚簇索引都需要额外的存储空间来存储索引键和指向数据行的指针。
  • 更新性能下降:插入、更新和删除操作需要维护非聚簇索引,这可能导致性能下降,尤其是在频繁的大批量数据更改情况下。
  • 索引选择的复杂性:在设计数据库时,需要仔细选择哪些列应该创建非聚簇索引,以避免不必要的索引浪费存储空间。

使用场景:

  • 支持频繁的查询操作:非聚簇索引适用于需要快速检索数据的查询操作,特别是针对某些列的查找、过滤和排序操作。
  • 覆盖查询需求:当查询需要覆盖索引中的所有列,非聚簇索引是一个不错的选择,因为它可以减少对数据行的访问次数。
  • 辅助索引:非聚簇索引通常用于支持数据表的主要聚簇索引以外的其他查询需求,例如范围查询、联接操作等。

在MyISAM与InnoDB中的使用

MyISAM 与 InnoDB 是两种不同的存储引擎,它们在索引和数据存储方面有很多区别。以下是它们之间的主要比较:

  1. 索引类型

    • MyISAM 使用非聚簇索引,所有索引都是二级索引,不包含实际数据记录。
    • InnoDB 包含一个聚簇索引,可以根据主键值一次查找实际数据记录。
  2. 数据文件和索引文件

    • InnoDB 的数据文件本身就是索引文件,包含实际数据记录。
    • MyISAM 的索引文件和数据文件是分离的,索引文件只保存数据记录的地址。
  3. 非聚簇索引中的数据存储

    • InnoDB 的非聚簇索引中的data域存储相应记录的主键值。
    • MyISAM 的索引记录存储的是数据记录的地址。
  4. 回表操作

    • MyISAM 的回表操作是快速的,因为它直接使用地址偏移量来获取数据记录。
      • “回表”:在数据库查询中,当使用非聚簇索引(或次要索引)来查找数据时,需要额外的步骤来获取完整的数据行。
    • InnoDB 通过获取主键之后再去聚簇索引中找记录,虽然也较快,但不如直接使用地址来访问。
  5. 主键要求

    • InnoDB 要求表必须有主键,如果没有显式指定,MySQL会自动选择一个非空且唯一标识数据记录的列作为主键。
    • MyISAM 可以没有显式主键。

总之,InnoDB 的设计更加适用于需要事务支持和高并发读写的应用,而MyISAM 更适合于只有读操作的应用,或者不需要事务支持的情况。选择哪种引擎应该根据具体的应用需求来决定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/111089.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis AOF持久化和ReWrite

前言 Redis 的 RDB 持久化机制简单直接,把某一时刻的所有键值对以二进制的方式写入到磁盘,特点是恢复速度快,尤其适合数据备份、主从复制场景。但如果你的目的是要保证数据可靠性,RDB 就不太适合了,因为 RDB 持久化不…

关闭mysql,关闭redis服务

1. 关闭redis服务: 查询redis安装目录: whereis redis which redis find / -name redis 关闭redis服务: redis-cli -h 127.0.0.1 -p 6379 auth 输入密码 shutdown 关闭redis服务 2. 关闭mysql服务: 查询mysql安装目录&…

Typora 导出PDF 报错 failed to export as pdf. undefined 解决方案

情况 我想把一个很大的markdown 导出为 248页的pdf 然后就报错 failed to export as pdf. undefined 原因 : 个人感觉应该是图片太大了 格式问题之类导致的 解决 文件 -> 偏好设置 - > 导出 -> pdf -> 自定义 -> 把大小全部改为24mm (虽然图中是32 …

模拟IIC通讯协议(stm32)(硬件iic后面在补)

一、IIC基础知识总结。 1、IIC通讯需要两条线就可以,SCL、SDA。 2、IIC的数据传输的速率,不同的ic是不同的,根据电平维持的延时函数的时间来确定IIC数据传输的速率. 3、IIC的延时函数可以使用延时函数,延时函数一般使用系统滴答时…

安防监控系统EasyCVR视频汇聚平台设备树收藏按钮的细节优化

视频监控TSINGSEE青犀视频平台EasyCVR能在复杂的网络环境中,将分散的各类视频资源进行统一汇聚、整合、集中管理,在视频监控播放上,TSINGSEE青犀视频安防监控汇聚平台可支持1、4、9、16个画面窗口播放,可同时播放多路视频流&#…

【Linux】:Linux环境与版本

以下哪个命令输出Linux内核的版本信息 A.uname -r B.vmstat C.sar D.stat uname -r 查看linux内核版本信息 vmstat 报告关于内核线程、虚拟内存、磁盘、陷阱和 CPU 活动的统计信息 sar 主要帮助我们掌握系统资源的使用情况,特别是内存和CPU的使用情况 stat 用于显示…

家政系统预约小程序具备哪些功能?

预约家政小程序有这么大的市场需求加上这么多的好处,相信未来发展前景不错。也必将吸引很多商家投资者着手开发属于自己的上门家政APP小程序软件,在实际的开发过程中需要具备哪些功能呢? 一、用户端功能: 1. 用户注册登录&#x…

了解 AI :了解 AI 方面的一些术语 (中英文对照)

本心、输入输出、结果 文章目录 了解 AI :了解 AI 方面的一些术语 (中英文对照)前言AI 方面的一些术语 (中英文对照)AI 方面的一些术语 (中英文对照) - 文字版弘扬爱国精神 了解 AI &#xff1a…

什么是热阻?

电流流过导体时,在导体两端会产生电压差,这个电压差除以流过导体的电流就是这个导体的电阻,单位是欧姆。这就是欧姆定律,大家都知道的东西。 当热源的热量在物体中传递时,在物体上也会产生温度差,这个温度差…

UE4 UltrDynamicSky与场景物体进行交互

找到材质 找到其最父类的材质 把这个拖过去连上即可

Canal

目录 一、认识Canal二、安装和配置Canal1、安装mysql2.开启MySQL主从3.安装Canal 三、监听Canal1.引入依赖:2.编写配置:3.修改Item实体类4.编写监听器 学习Redis 高级篇多级缓存【缓存同步】时,相关canal的知识 一、认识Canal Canal [kə’…

MySQL的自增id会用完吗?用完怎么办?

MySQL作为最常用的关系型数据库,无论是在应用还是在面试中都是必须掌握的技能。 目录 一、MySQL自增主键会用完吗 二、MySQL自增主键用完会怎样 1.程序员自己设置的自增主键 2.程序员没有设置自增主键,mysql自动创建row_id 三、mysql中还有哪些自增…

2023年Q3季度国内手机大盘销额下滑2%,TOP品牌销售数据分析

根据Canalys机构发布的最新报告,2023年第三季度,全球智能手机市场出货量仅下跌1%,可以认为目前全球手机市场的下滑势头有所减缓。而国内线上市场的表现也类似。 根据鲸参谋数据显示,今年Q3京东平台手机累计销量约1100万件&#xf…

第十六届中国智慧城市大会 | 国产化三维重建技术服务智慧城市建设

2023年10月13日,由武汉大势智慧科技有限公司、飞燕航空遥感技术有限公司主办的第十六届智慧城市大会-实景三维技术创新与应用论坛在广州成功举办。 来自实景三维、自然资源、数字孪生、AI大数据、航空遥感等多个领域的专家,深度分享各自的智慧城市建设经…

vue3后台管理系统之layout组件的搭建

1.1静态布局 <template><div class"layout_container"><!-- 左侧导航 --><div class"layout_slider"></div><!-- 顶部导航 --><div class"layout_tabbar"></div><!-- 内容展示区 --><…

C# LINQ常用操作方法——提升你的编程效率

导语&#xff1a;C# LINQ&#xff08;Language Integrated Query&#xff09;是一种强大且灵活的查询语言&#xff0c;可以将数据查询、过滤、排序和转换等操作无缝集成到C#代码中。本文将介绍一些常用的LINQ操作方法&#xff0c;帮助熟练掌握LINQ的使用&#xff0c;并进一步提…

王道计算机考研 操作系统学习笔记篇章二: 进程管理

目录 进程与线程 进程的概念 概念 进程的组成 PCB 程序段、数据段 进程的特征 总结 进程的状态与转换 进程的状态 创建态、就绪态 运行态 阻塞态 终止态 进程的转换 进程的组织 链接方式 索引方式 总结 进程控制 什么是进程控制 如何实现进程控制 进程控制相关的原…

pycharm远程连接miniconda完整过程,以及遇到的问题解决

问题1&#xff1a;no-zero exit code(126) env: ‘/home/user2/miniconda3/envs/ihan/bin/python3’: Too many levels of symbolic links Python interpreter process exited with a non-zero exit code 126 因为选择的新建导致太多软连接&#xff0c;先在服务器上建好虚拟环…

使用Portainer图形化工具轻松管理远程Docker环境并实现远程访问

文章目录 前言1. 部署Portainer2. 本地访问Portainer3. Linux 安装cpolar4. 配置Portainer 公网访问地址5. 公网远程访问Portainer6. 固定Portainer公网地址 前言 Portainer 是一个轻量级的容器管理工具&#xff0c;可以通过 Web 界面对 Docker 容器进行管理和监控。它提供了可…

solidworks 2024新功能之--保存为低版本 硕迪科技

大家期盼已久的SOLIDWORKS保存低版本文件功能来了&#xff0c;从SOLIDWORKS 2024 开始&#xff0c;您可以将在最新版本的SOLIDWORKS 中创建的SOLIDWORKS零件、装配体和工程图另存为SOLIDWORKS 早期版本的全功能文档&#xff08;完成的特征树与相关参数&#xff09;。 将文件另…