关于 B+tree 索引的疑问

2020-03-28 19:34:26 +08:00
 zxc1234

关于 B+tree 的疑问

mysql 中 innodb 引擎索引使用 B+tree

我看网上资料说 ===:

( B+ 树中的节点不存储数据,只是索引,而 B 树中的节点存储数据)

可是 innodb 的主键索引的叶子节点就是数据啊

请问 是哪里不对吗

2130 次点击
所在节点    程序员
10 条回复
Stevenv
2020-03-28 19:47:29 +08:00
分内部节点,叶子节点。B+Tree:内部节点不存值,子节点存值。B-Tree:内部节点、子节点都存值
holosola
2020-03-28 19:47:57 +08:00
你这么理解吧,B+ 树数据只存储在叶子节点,B 树每个节点都存储了数据。
gosansam
2020-03-28 21:23:48 +08:00
主键列的索引 叶子结点存储完整的数据,非主键索引在叶子节点存储索引列+主键等,增加一次主键索引查询(高效果),避免浪费空间
hhyvs111
2020-03-28 23:06:13 +08:00
网上资料是错的
SmartKeyerror
2020-03-29 11:07:38 +08:00
在网上遇到自己不确定知识点的时候,最简单且有效的办法就是自己动手验证。MySQL InnoDB 存储引擎实际存储就 3 个文件: .opt, .frm, .ibd ,其中.ibd 为实际存储数据和索引的地方,聚簇索引和辅助索引数据均在该文件中。建一张测试表,写点儿数据,然后闷头分析.ibd 文件就行了。
当初我对这东西也很有疑问,动手分析了之后明白了个大概。https://smartkeyerror.com/MySQL-physical-structure,后面自己写了篇博客,希望对你有帮助。
PS: 推荐《 MySQL 技术内幕-InnoDB 存储引擎》,相信能解答你许多疑惑。
LudwigWS
2020-03-29 12:43:55 +08:00
@SmartKeyerror 向大佬学习
SmartKeyerror
2020-03-29 14:40:44 +08:00
@LudwigWS 不是大佬,无名小卒而已..
andj4cn
2020-03-29 18:26:26 +08:00
scriptB0y
2020-03-29 18:29:32 +08:00
@andj4cn 微信的图无法显示。
zxc1234
2020-03-29 20:23:45 +08:00
@andj4cn 请问 b 树的图呢 有吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/657136

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX