非聚簇索引
创始人
2024-12-27 01:05:15
0
  • B+ 树的非叶子节点不存放实际的记录数据,仅存放索引,因此数据量相同的情况下,相比存储即存索引又存记录的 B 树,B+树的非叶子节点可以存放更多的索引,因此 B+ 树可以比 B 树更「矮胖」,查询底层节点的磁盘 I/O次数会更少。

  • B+ 树有大量的冗余节点(所有非叶子节点都是冗余索引),这些冗余索引让 B+ 树在插入、删除的效率都更高,比如删除根节点的时候,不会像 B 树那样会发生复杂的树的变化;

  • B+ 树叶子节点之间用链表连接了起来,有利于范围查询,而 B 树要实现范围查询,因此只能通过树的遍历来完成范围查询,这会涉及多个节点的磁盘 I/O 操作,范围查询效率不如 B+ 树。

在 MySQL 的 InnoDB 引擎中,每个索引都会对应一颗 B+ 树,而聚簇索引和非聚簇索引最大的区别在于叶子节点存储的数据不同,聚簇索引叶子节点存储的是行数据,因此通过聚簇索引可以直接找到真正的行数据;而非聚簇索引叶子节点存储的是主键id,所以使用非聚簇索引还需要回表查询。

因此聚簇索引和非聚簇索引的区别主要有以下几个:

  • 聚簇索引叶子节点存储的是行数据;而非聚簇索引叶子节点存储的是聚簇索引(通常是主键 ID)。

  • 聚簇索引查询效率更高,而非聚簇索引需要进行回表查询,因此性能不如聚簇索引。

  • 聚簇索引一般为主键索引,而主键一个表中只能有一个,因此聚簇索引一个表中也只能有一个,而非聚簇索引则没有数量上的限制。

隔离级别越高,性能效率就越低 

读未提交,指一个事务还没提交时,它做的变更就能被其他事务看到;

读提交,指一个事务提交之后,它做的变更才能被其他事务看到;

可重复读,指一个事务执行过程中看到的数据,一直跟这个事务启动时看到的数据是一致的,MySQL InnoDB 引擎的默认隔离级别

串行化;会对记录加上读写锁,在多个事务对这条记录进行读写操作时,如果发生了读写冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行;

 

相关内容

热门资讯

一起来探讨!微信微乐辅助,we... 一起来探讨!微信微乐辅助,wejoker私人辅助软件,手筋教程(新版有挂)-哔哩哔哩暗藏猫腻,小编详...
辅助透视!wepoker私人局... 辅助透视!wepoker私人局透视插件,微乐家乡麻辣自建房,手筋教程(有挂秘诀)-哔哩哔哩1、wep...
此事迅速冲上热搜!哈糖大菠萝开... 此事迅速冲上热搜!哈糖大菠萝开挂,越乡游辅助脚本,秘籍教程(有人有挂)-哔哩哔哩1)哈糖大菠萝开挂辅...
今日!随意玩聚乐部辅助,广东闲... 今日!随意玩聚乐部辅助,广东闲来辅助,大纲教程(确实有挂)-哔哩哔哩1、任何随意玩聚乐部辅助透视是真...
我来分享!南丰数刀脚本,德州局... 我来分享!南丰数刀脚本,德州局怎么透视,妙招教程(有挂秘诀)-哔哩哔哩小薇(辅助器软件下载)致您一封...
解密透视!拱趴大菠萝挂怎么安装... 解密透视!拱趴大菠萝挂怎么安装,微信小程序微乐内蒙破解器,要领教程(有挂分析)-哔哩哔哩该软件可以轻...
黑科技技巧!约局吧德州有挂吗,... 黑科技技巧!约局吧德州有挂吗,hhpoker有没有作比,积累教程(有挂功能)-哔哩哔哩1、任何约局吧...
有玩家发现!新圣游脚本下载,火... 有玩家发现!新圣游脚本下载,火神工作室辅助大全,操作教程(了解有挂)-哔哩哔哩1、火神工作室辅助大全...
专业讨论!!神兽互娱辅助免费,... 专业讨论!!神兽互娱辅助免费,红龙poker辅助器免费观看,攻略教程(有挂详情)-哔哩哔哩1、全新机...
2026版教程!pokemmo... 2026版教程!pokemmo脚本最新版,微信新九游辅助,资料教程(有挂方略)-哔哩哔哩1、首先打开...