Files
oceanbase/docs/docs-cn/5.overview/6.storage-architecture/3.memory-table.md
2022-02-10 14:51:49 +08:00

25 lines
2.0 KiB
Markdown

内存表 MEMTable
=================================
MEMTable 中的数据结构
------------------------
OceanBase 数据库的内存存储引擎 MEMTable 由 BTree 和 Hashtable 组成,在插入/更新/删除数据时,数据被写入内存块,在 HashTable 和 BTree 中存储的均为指向对应数据的指针。
![存储图片 1.png](https://help-static-aliyun-doc.aliyuncs.com/assets/img/zh-CN/3317076061/p184508.png "存储图片 1.png")
两种数据结构的特点
------------------
| **数据结构** | **优点** | **缺点** |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| HashTable | 插入一行数据的时候,需要先检查此行数据是否已经存在,当且仅当数据不存在时才能插入,检查冲突时,用 Hashtable 要比 BTree 快。 事务在插入或更新一行数据的时候,需要找到此行并对其进行上锁,防止其它事务修改此行,OceanBase 数据库的行锁放在 `ObMvccRow` 中,需要先找到它,才能上锁。 | 不适合对范围查询使用 HashTable。 |
| BTree | 范围查找时,由于 BTree Node 中的数据都是有序的,因此只需要搜索局部的数据就可以了。 | 单行的查找,也需要进行大量的 Rowkey 比较,从根结点找到叶子结点,而 Rowkey 比较性能是较差的,因此理论上性能比 HashTable 慢很多。 |