MongoDB索引底层实现原理分析

本文分析了MongoDB与MySQL底层索引的实现原理,重点对比了B树(MongoDB采用)和B+树(MySQL采用)的差异。B树适合随机读写,而B+树的相邻节点指针优化了区间查询性能,更适合磁盘存储,充分利用磁盘预读。两者在数据保存位置和区间访问效率上存在显著区别。
摘要由CSDN通过智能技术生成

简介

MongoDB是文档型的数据库,它使用BSON格式保存数据,比关系型数据库存储更方便,比如之前关系型数据库中处理用户、订单等数据要建立对应的表,还要建立它们之间的关联关系。但是BSON就不一样了,我们可以把一条数据和这条数据对应的数据都存入一个BSON对象中,这种形式更简单,通俗易懂。MySql是关系型数据库,数据的关联性是非常强的,区间访问是常见的一种情况,底层索引组织数据使用B+树,B+树由于数据都存储在叶子节点,并且通过指针串在一起,这样就很容易的进行区间遍历货值全部遍历。MongoDB使用B-树,所有节点都有Data域,只要找到指定索引就可以进行访问,单次查询从结构上要快于MySql。

 

MongoDB采用的是B树(B-树),其特点为:

  1. 多路非二叉树
  2. 每个节点既保存数据又保存索引
  3. 搜索时相当于二分查找

 

B+树是B树的变种,MySql才用的是B+树,其特点为:

  1. 多路非二叉树
  2. 只有叶子节点才保存数据
  3. 搜索时也相当于二分查找
  4. 增加了相邻节点指针
  5. </
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值