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

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

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

Redis的Hash类型及相关命令小结

《Redis的Hash类型及相关命令小结》edisHash是一种数据结构,用于存储字段和值的映射关系,本文就来介绍一下Redis的Hash类型及相关命令小结,具有一定的参考价值,感兴趣的可以了解一下... 目录HSETHGETHEXISTSHDELHKEYSHVALSHGETALLHMGETHLENHSET

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置