mysql索引之二级索引学习总结

二级索引又称辅助索引、非聚集索引(no-clustered index)。b+tree树结构。然而二级索引的叶子节点不保存记录中的所有列,其叶子节点保存的是<健值,(记录)地址>。好似聚集索引中非叶子节点保存的信息,不同的是二级索引保存的是记录地址,而聚集索引保存的是下一层节点地址。记录的地址一般可以保存两种形式。
1. 记录的物理地址,页号:槽号:偏移量
2 . 记录的主键值

innodb引擎是索引组织表,所有记录都放在聚集索引里,因此其辅助索引中的记录地址存放的主键的键值。

innodb读操作:

通过二级索引查询记录仅能得到主键值,要查询完整的记录还需要再通过一次聚集索引查询,这种查询方式为书签查找(bookmark lookup)。
注:聚集索引:例如查字典,每个字所在的位置有一个页码,如果你知道一个字的所在具体页数便可直接翻到相应的页,此刻可以把字典中的页码看成主键。字典的正文就是一个查询目录而不需要在通过其他目录来查找。这种正文本身具有一定的规则排序的目录称为聚集索引。
二级索引:此操作就如查字典,先找到生字的偏旁部首查找到字在哪一页(获得主键的位置),然后再翻到生字的具体章节叶。

innodb写操作:

仅当主键发生改变时,才会更新二级索引

二级索引的非叶子节点存放的记录格式为<键值,主键值,地址>,二级索引的非叶子节点依然存在主键信息。二级索引节点的记录不保存隐藏列xid和roll ptr。聚集索引的非叶子节点保存的是下一层节点地址。
由于二级索引不包含记录的完整信息,在innodb存储引擎中二级索引的树高度比聚簇索引的树高度小,二级索引效率低。

知识关联:聚簇索引和辅助索引的区别
交流群:725450393
在这里插入图片描述

MySQL中的一级索引又称为聚集索引,通常是主键索引。一级索引索引和数据存储在一起,存储在同一个B树中的叶子节点。当使用一级索引进行查询时,可以直接定位到数据行。例如,在一个表中使用id作为主键创建了一级索引,当执行`SELECT * FROM table WHERE id = 1;`时,只需要读取少量磁盘块就可以获取到对应的数据。 而二级索引又称为聚集索引或次要索引,是在一级索引之外创建的索引,用于提高主键列的查询性能。二级索引通常包含索引列和指向数据行的指针,可以通过索引列快速定位到数据行。当使用二级索引进行查询时,首先通过二级索引找到对应的主键值,然后再使用一级索引找到对应的数据记录。例如,如果根据字段plname创建了二级索引,在执行`SELECT * FROM pl_ranking WHERE plname = 'Java';`时,首先通过二级索引找到Java对应的主键id,然后再通过一级索引找到对应的数据行。 因此,使用二级索引需要进行"回表"操作,即需要额外的一次查找。 一级索引二级索引之间的关系是,一级索引可以单独存在,而二级索引必须依附于一级索引二级索引存储的是主键值而不是实际的数据,这样可以减少数据冗余和维护工作。优点是减少了数据冗余,减少了行移动或数据页分裂时二级索引的维护工作。缺点是根据二级索引查找行的完整数据需要进行额外的回表操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [一级索引二级索引 的概念及使用](https://blog.csdn.net/m0_69057918/article/details/131066870)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [MySQL的一级索引二级索引介绍](https://blog.csdn.net/weixin_43606861/article/details/116202806)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值