非聚簇索引
创始人
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 引擎的默认隔离级别

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

 

相关内容

热门资讯

现有说明如下!wpk俱乐部是真... 现有说明如下!wpk俱乐部是真的吗,we-poker辅助(透视)手段教程(都是存在有挂)1、玩家可以...
无独有偶!约局吧德州有挂吗,w... 无独有偶!约局吧德州有挂吗,wepoker私人局外卦(透视)攻略教程(一直是真的挂)1、下载好约局吧...
长期以来!德普软件,拱趴大菠萝... 长期以来!德普软件,拱趴大菠萝挂哪里(透视)资料教程(一贯真的是有挂)1、完成拱趴大菠萝挂哪里辅助器...
无独有偶!aapoker辅助软... 无独有偶!aapoker辅助软件合法吗,aapoker万能辅助器(透视)模块教程(其实真的是有挂)一...
随着!智星德州可以透视吗,we... 随着!智星德州可以透视吗,wepoker免费脚本弱密码(透视)指南教程(好像真的有挂)1、每一步都需...
更值得关注的是!epoker免... 更值得关注的是!epoker免费透视脚本,悦扑克脚本(透视)手筋教程(切实是有挂)1、进入游戏-大厅...
截至目前!wepokerplu... 截至目前!wepokerplus透视脚本免费,hhpoker辅助挂(透视)讲义教程(好像真的有挂)1...
现有说明如下!wepoker脚... 现有说明如下!wepoker脚本,wepoker辅助软件视频(透视)总结教程(果然存在有挂)1、we...
刚刚!hhpoker可以控制牌... 刚刚!hhpoker可以控制牌吗,wepoker轻量版透视方法(透视)教材教程(其实是真的挂)暗藏猫...
无独有偶!hhpoker是真的... 无独有偶!hhpoker是真的还是假的,wpk德州局怎么透视(透视)阶段教程(好像存在有挂)1.hh...