聚簇索引和非聚簇索引(相关小知识点)

2024-09-05 20:58

本文主要是介绍聚簇索引和非聚簇索引(相关小知识点),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

终于有时间写写博客,记录下聚簇索引与非聚簇索引的相关小知识点。

知识点

1、聚簇索引和非聚簇索引的各自适用场景?

2、聚簇索引和非聚簇索引的优劣势?

优势:

  • 叶子节点会存储数据,找到叶子节点就找到了数据行,无需回表;

  • 对于辅助索引,使用主键作为指针而不是地址值,,减少了出现行移动或者数据页分裂时辅助索引的维护工作;

  • 在排序场景下,由于聚簇索引的物理位置和数据行的逻辑位置的有序性,效率更高;

  • 范围查找适用聚簇索引;

劣势:

  • 维护索引代价比较昂贵,移动行时会形成碎片;

  • 主键是随机值时,使用聚簇索引会比全表扫描更慢,因为每次插入数据都有可能会出现大量行移动;

  • 主键较大时,不要使用聚簇索引,因为此时辅助索引也会变得更大(所有辅助索引叶子节点的值都是主键值)

3、主键使用自增id的好处?

聚簇索引的数据的物理存放顺序和索引顺序一致,也就是说,在磁盘上也是连续存储的,这样可以减少内存碎片,同时减少数据物理地址的调整,这里需要注意的是Myisam的主索引和辅助索引实际上是一样的(个人理解),都是非聚簇索引,其物理地址实际是不相邻的,在查找时可能会有多次IO,如图:

                                                             

但是,当涉及到大数据量的排序(注意是大数据量的排序)和全表扫描时,还是Myisam比较适用,因为索引占空间较小,而排序操作是需要在内存中完成的。

4、索引的优化

  • 尽量选择较小的数据类型,这样节点存储的key就多,树的高度就小,从而可以减少IO次数;

  • 选择离散度高的列作为索引,越有利于数据的查找,当离散到一定程度就是全表扫描;

  • 联合索引尽量把离散度高的、索引长度小的放前面

5、索引失效场景

  • like以%开头,如like “%1232%”

  • not in和<>操作会使索引失效,因为b+tree本质是二分查找树,无法根据这些操作符做出选择;

  • select尽量使用指定列查询,避免使用select *,这样可以使用到覆盖索引;

  • 联合索引不符合最左匹配时会使索引失效;

  • 最左匹配原则从最左一列开始,直至遇到范围查询停止,其右边的列都无法用到索引;

总结

回表不一定会更慢,使用索引也不一定比全表快,怎么用好索引是门很深的学问。

这篇关于聚簇索引和非聚簇索引(相关小知识点)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1140052

相关文章

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

MySQL索引失效问题及解决方案

《MySQL索引失效问题及解决方案》:本文主要介绍MySQL索引失效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql索引失效一、概要二、常见的导致MpythonySQL索引失效的原因三、如何诊断MySQL索引失效四、如何解决MySQL索引失

解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题

《解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:org.junit.Test问题》:本文主要介绍解决tomcat启动时报Junit相... 目录tomcat启动时报Junit相关错误Java.lang.ClassNotFoundException

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

JavaScript Array.from及其相关用法详解(示例演示)

《JavaScriptArray.from及其相关用法详解(示例演示)》Array.from方法是ES6引入的一个静态方法,用于从类数组对象或可迭代对象创建一个新的数组实例,本文将详细介绍Array... 目录一、Array.from 方法概述1. 方法介绍2. 示例演示二、结合实际场景的使用1. 初始化二

Mysql中InnoDB与MyISAM索引差异详解(最新整理)

《Mysql中InnoDB与MyISAM索引差异详解(最新整理)》InnoDB和MyISAM在索引实现和特性上有差异,包括聚集索引、非聚集索引、事务支持、并发控制、覆盖索引、主键约束、外键支持和物理存... 目录1. 索引类型与数据存储方式InnoDBMyISAM2. 事务与并发控制InnoDBMyISAM