Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
oceanbase
miniob
提交
02429ff7
M
miniob
项目概览
oceanbase
/
miniob
1 年多 前同步成功
通知
74
Star
1521
Fork
537
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
分析
仓库
DevOps
项目成员
Pages
M
miniob
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Pages
分析
分析
仓库分析
DevOps
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
提交
未验证
提交
02429ff7
编写于
4月 02, 2022
作者:
羽飞
提交者:
GitHub
4月 02, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #31 from hnwyllmm/refactor/btree-1
再次重写B+树
上级
0dd25aae
d30c592f
变更
10
展开全部
隐藏空白更改
内联
并排
Showing
10 changed file
with
2370 addition
and
2169 deletion
+2370
-2169
src/observer/storage/common/bplus_tree.cpp
src/observer/storage/common/bplus_tree.cpp
+1451
-1965
src/observer/storage/common/bplus_tree.h
src/observer/storage/common/bplus_tree.h
+373
-156
src/observer/storage/common/bplus_tree_index.cpp
src/observer/storage/common/bplus_tree_index.cpp
+15
-12
src/observer/storage/common/bplus_tree_index.h
src/observer/storage/common/bplus_tree_index.h
+8
-3
src/observer/storage/common/index.h
src/observer/storage/common/index.h
+7
-2
src/observer/storage/common/record_manager.h
src/observer/storage/common/record_manager.h
+23
-2
src/observer/storage/common/table.cpp
src/observer/storage/common/table.cpp
+37
-1
src/observer/storage/default/disk_buffer_pool.cpp
src/observer/storage/default/disk_buffer_pool.cpp
+28
-4
src/observer/storage/default/disk_buffer_pool.h
src/observer/storage/default/disk_buffer_pool.h
+12
-0
unitest/bplus_tree_test.cpp
unitest/bplus_tree_test.cpp
+416
-24
未找到文件。
src/observer/storage/common/bplus_tree.cpp
浏览文件 @
02429ff7
此差异已折叠。
点击以展开。
src/observer/storage/common/bplus_tree.h
浏览文件 @
02429ff7
此差异已折叠。
点击以展开。
src/observer/storage/common/bplus_tree_index.cpp
浏览文件 @
02429ff7
...
@@ -100,17 +100,16 @@ RC BplusTreeIndex::delete_entry(const char *record, const RID *rid)
...
@@ -100,17 +100,16 @@ RC BplusTreeIndex::delete_entry(const char *record, const RID *rid)
return
index_handler_
.
delete_entry
(
record
+
field_meta_
.
offset
(),
rid
);
return
index_handler_
.
delete_entry
(
record
+
field_meta_
.
offset
(),
rid
);
}
}
IndexScanner
*
BplusTreeIndex
::
create_scanner
(
CompOp
comp_op
,
const
char
*
value
)
IndexScanner
*
BplusTreeIndex
::
create_scanner
(
const
char
*
left_key
,
bool
left_inclusive
,
const
char
*
right_key
,
bool
right_inclusive
)
{
{
BplusTree
Scanner
*
bplus_tree_scanner
=
new
BplusTree
Scanner
(
index_handler_
);
BplusTree
IndexScanner
*
index_scanner
=
new
BplusTreeIndex
Scanner
(
index_handler_
);
RC
rc
=
bplus_tree_scanner
->
open
(
comp_op
,
valu
e
);
RC
rc
=
index_scanner
->
open
(
left_key
,
left_inclusive
,
right_key
,
right_inclusiv
e
);
if
(
rc
!=
RC
::
SUCCESS
)
{
if
(
rc
!=
RC
::
SUCCESS
)
{
LOG_WARN
(
"
Failed to open index scanner. file_id:%d, rc=%d:%s"
,
index_handler_
.
get_file_id
()
,
rc
,
strrc
(
rc
));
LOG_WARN
(
"
failed to open index scanner. rc=%d:%s"
,
rc
,
strrc
(
rc
));
delete
bplus_tree
_scanner
;
delete
index
_scanner
;
return
nullptr
;
return
nullptr
;
}
}
BplusTreeIndexScanner
*
index_scanner
=
new
BplusTreeIndexScanner
(
bplus_tree_scanner
);
return
index_scanner
;
return
index_scanner
;
}
}
...
@@ -120,22 +119,26 @@ RC BplusTreeIndex::sync()
...
@@ -120,22 +119,26 @@ RC BplusTreeIndex::sync()
}
}
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
BplusTreeIndexScanner
::
BplusTreeIndexScanner
(
BplusTree
Scanner
*
tree_scanner
)
:
tree_scanner_
(
tree_scann
er
)
BplusTreeIndexScanner
::
BplusTreeIndexScanner
(
BplusTree
Handler
&
tree_handler
)
:
tree_scanner_
(
tree_handl
er
)
{}
{}
BplusTreeIndexScanner
::~
BplusTreeIndexScanner
()
noexcept
BplusTreeIndexScanner
::~
BplusTreeIndexScanner
()
noexcept
{
{
tree_scanner_
->
close
();
tree_scanner_
.
close
();
delete
tree_scanner_
;
}
RC
BplusTreeIndexScanner
::
open
(
const
char
*
left_key
,
bool
left_inclusive
,
const
char
*
right_key
,
bool
right_inclusive
)
{
return
tree_scanner_
.
open
(
left_key
,
left_inclusive
,
right_key
,
right_inclusive
);
}
}
RC
BplusTreeIndexScanner
::
next_entry
(
RID
*
rid
)
RC
BplusTreeIndexScanner
::
next_entry
(
RID
*
rid
)
{
{
return
tree_scanner_
->
next_entry
(
rid
);
return
tree_scanner_
.
next_entry
(
rid
);
}
}
RC
BplusTreeIndexScanner
::
destroy
()
RC
BplusTreeIndexScanner
::
destroy
()
{
{
delete
this
;
delete
this
;
return
RC
::
SUCCESS
;
return
RC
::
SUCCESS
;
}
}
\ No newline at end of file
src/observer/storage/common/bplus_tree_index.h
浏览文件 @
02429ff7
...
@@ -30,7 +30,11 @@ public:
...
@@ -30,7 +30,11 @@ public:
RC
insert_entry
(
const
char
*
record
,
const
RID
*
rid
)
override
;
RC
insert_entry
(
const
char
*
record
,
const
RID
*
rid
)
override
;
RC
delete_entry
(
const
char
*
record
,
const
RID
*
rid
)
override
;
RC
delete_entry
(
const
char
*
record
,
const
RID
*
rid
)
override
;
IndexScanner
*
create_scanner
(
CompOp
comp_op
,
const
char
*
value
)
override
;
/**
* 扫描指定范围的数据
*/
IndexScanner
*
create_scanner
(
const
char
*
left_key
,
bool
left_inclusive
,
const
char
*
right_key
,
bool
right_inclusive
)
override
;
RC
sync
()
override
;
RC
sync
()
override
;
...
@@ -41,14 +45,15 @@ private:
...
@@ -41,14 +45,15 @@ private:
class
BplusTreeIndexScanner
:
public
IndexScanner
{
class
BplusTreeIndexScanner
:
public
IndexScanner
{
public:
public:
BplusTreeIndexScanner
(
BplusTree
Scanner
*
tree_scanner
);
BplusTreeIndexScanner
(
BplusTree
Handler
&
tree_handle
);
~
BplusTreeIndexScanner
()
noexcept
override
;
~
BplusTreeIndexScanner
()
noexcept
override
;
RC
next_entry
(
RID
*
rid
)
override
;
RC
next_entry
(
RID
*
rid
)
override
;
RC
destroy
()
override
;
RC
destroy
()
override
;
RC
open
(
const
char
*
left_key
,
bool
left_inclusive
,
const
char
*
right_key
,
bool
right_inclusive
);
private:
private:
BplusTreeScanner
*
tree_scanner_
;
BplusTreeScanner
tree_scanner_
;
};
};
#endif //__OBSERVER_STORAGE_COMMON_BPLUS_TREE_INDEX_H_
#endif //__OBSERVER_STORAGE_COMMON_BPLUS_TREE_INDEX_H_
src/observer/storage/common/index.h
浏览文件 @
02429ff7
...
@@ -46,7 +46,8 @@ public:
...
@@ -46,7 +46,8 @@ public:
virtual
RC
insert_entry
(
const
char
*
record
,
const
RID
*
rid
)
=
0
;
virtual
RC
insert_entry
(
const
char
*
record
,
const
RID
*
rid
)
=
0
;
virtual
RC
delete_entry
(
const
char
*
record
,
const
RID
*
rid
)
=
0
;
virtual
RC
delete_entry
(
const
char
*
record
,
const
RID
*
rid
)
=
0
;
virtual
IndexScanner
*
create_scanner
(
CompOp
comp_op
,
const
char
*
value
)
=
0
;
virtual
IndexScanner
*
create_scanner
(
const
char
*
left_key
,
bool
left_inclusive
,
const
char
*
right_key
,
bool
right_inclusive
)
=
0
;
virtual
RC
sync
()
=
0
;
virtual
RC
sync
()
=
0
;
...
@@ -63,8 +64,12 @@ public:
...
@@ -63,8 +64,12 @@ public:
IndexScanner
()
=
default
;
IndexScanner
()
=
default
;
virtual
~
IndexScanner
()
=
default
;
virtual
~
IndexScanner
()
=
default
;
/**
* 遍历元素数据
* 如果没有更多的元素,返回RECORD_EOF
*/
virtual
RC
next_entry
(
RID
*
rid
)
=
0
;
virtual
RC
next_entry
(
RID
*
rid
)
=
0
;
virtual
RC
destroy
()
=
0
;
virtual
RC
destroy
()
=
0
;
};
};
#endif // __OBSERVER_STORAGE_COMMON_INDEX_H_
#endif // __OBSERVER_STORAGE_COMMON_INDEX_H_
\ No newline at end of file
src/observer/storage/common/record_manager.h
浏览文件 @
02429ff7
...
@@ -17,7 +17,7 @@ See the Mulan PSL v2 for more details. */
...
@@ -17,7 +17,7 @@ See the Mulan PSL v2 for more details. */
#include <sstream>
#include <sstream>
#include "storage/default/disk_buffer_pool.h"
#include "storage/default/disk_buffer_pool.h"
typedef
int
SlotNum
;
typedef
int
32_t
SlotNum
;
class
ConditionFilter
;
class
ConditionFilter
;
...
@@ -48,6 +48,11 @@ struct RID {
...
@@ -48,6 +48,11 @@ struct RID {
return
page_num
==
other
.
page_num
&&
slot_num
==
other
.
slot_num
;
return
page_num
==
other
.
page_num
&&
slot_num
==
other
.
slot_num
;
}
}
bool
operator
!=
(
const
RID
&
other
)
const
{
return
!
(
*
this
==
other
);
}
static
int
compare
(
const
RID
*
rid1
,
const
RID
*
rid2
)
static
int
compare
(
const
RID
*
rid1
,
const
RID
*
rid2
)
{
{
int
page_diff
=
rid1
->
page_num
-
rid2
->
page_num
;
int
page_diff
=
rid1
->
page_num
-
rid2
->
page_num
;
...
@@ -57,6 +62,22 @@ struct RID {
...
@@ -57,6 +62,22 @@ struct RID {
return
rid1
->
slot_num
-
rid2
->
slot_num
;
return
rid1
->
slot_num
-
rid2
->
slot_num
;
}
}
}
}
/**
* 返回一个不可能出现的最小的RID
* 虽然page num 0和slot num 0都是合法的,但是page num 0通常用于存放meta数据,所以对数据部分来说都是
* 不合法的. 这里在bplus tree中查找时会用到。
*/
static
RID
*
min
()
{
static
RID
rid
{
0
,
0
};
return
&
rid
;
}
static
RID
*
max
()
{
static
RID
rid
{
std
::
numeric_limits
<
PageNum
>::
max
(),
std
::
numeric_limits
<
SlotNum
>::
max
()};
return
&
rid
;
}
};
};
class
RidDigest
{
class
RidDigest
{
...
@@ -222,4 +243,4 @@ private:
...
@@ -222,4 +243,4 @@ private:
RecordPageHandler
record_page_handler_
;
RecordPageHandler
record_page_handler_
;
};
};
#endif //__OBSERVER_STORAGE_COMMON_RECORD_MANAGER_H_
#endif //__OBSERVER_STORAGE_COMMON_RECORD_MANAGER_H_
\ No newline at end of file
src/observer/storage/common/table.cpp
浏览文件 @
02429ff7
...
@@ -768,7 +768,43 @@ IndexScanner *Table::find_index_for_scan(const DefaultConditionFilter &filter)
...
@@ -768,7 +768,43 @@ IndexScanner *Table::find_index_for_scan(const DefaultConditionFilter &filter)
return
nullptr
;
return
nullptr
;
}
}
return
index
->
create_scanner
(
filter
.
comp_op
(),
(
const
char
*
)
value_cond_desc
->
value
);
const
char
*
left_key
=
nullptr
;
const
char
*
right_key
=
nullptr
;
bool
left_inclusive
=
false
;
bool
right_inclusive
=
false
;
switch
(
filter
.
comp_op
())
{
case
EQUAL_TO
:
{
left_key
=
(
const
char
*
)
value_cond_desc
->
value
;
right_key
=
(
const
char
*
)
value_cond_desc
->
value
;
left_inclusive
=
true
;
right_inclusive
=
true
;
}
break
;
case
LESS_EQUAL
:
{
right_key
=
(
const
char
*
)
value_cond_desc
->
value
;
right_inclusive
=
true
;
}
break
;
case
GREAT_EQUAL
:
{
left_key
=
(
const
char
*
)
value_cond_desc
->
value
;
left_inclusive
=
true
;
}
break
;
case
LESS_THAN
:
{
right_key
=
(
const
char
*
)
value_cond_desc
->
value
;
right_inclusive
=
false
;
}
break
;
case
GREAT_THAN
:
{
left_key
=
(
const
char
*
)
value_cond_desc
->
value
;
left_inclusive
=
false
;
}
break
;
default:
{
return
nullptr
;
}
}
return
index
->
create_scanner
(
left_key
,
left_inclusive
,
right_key
,
right_inclusive
);
}
}
IndexScanner
*
Table
::
find_index_for_scan
(
const
ConditionFilter
*
filter
)
IndexScanner
*
Table
::
find_index_for_scan
(
const
ConditionFilter
*
filter
)
...
...
src/observer/storage/default/disk_buffer_pool.cpp
浏览文件 @
02429ff7
...
@@ -478,7 +478,7 @@ RC DiskBufferPool::purge_page(int file_id, PageNum page_num)
...
@@ -478,7 +478,7 @@ RC DiskBufferPool::purge_page(int file_id, PageNum page_num)
RC
DiskBufferPool
::
purge_page
(
Frame
*
buf
)
RC
DiskBufferPool
::
purge_page
(
Frame
*
buf
)
{
{
if
(
buf
->
pin_count
>
0
)
{
if
(
buf
->
pin_count
>
0
)
{
LOG_INFO
(
"Begin to free page %d of %d, but it's pinned, pin_count:%d."
,
LOG_INFO
(
"Begin to free page %d of %d
(file id)
, but it's pinned, pin_count:%d."
,
buf
->
page
.
page_num
,
buf
->
page
.
page_num
,
buf
->
file_desc
,
buf
->
file_desc
,
buf
->
pin_count
);
buf
->
pin_count
);
...
@@ -488,12 +488,12 @@ RC DiskBufferPool::purge_page(Frame *buf)
...
@@ -488,12 +488,12 @@ RC DiskBufferPool::purge_page(Frame *buf)
if
(
buf
->
dirty
)
{
if
(
buf
->
dirty
)
{
RC
rc
=
flush_page
(
buf
);
RC
rc
=
flush_page
(
buf
);
if
(
rc
!=
RC
::
SUCCESS
)
{
if
(
rc
!=
RC
::
SUCCESS
)
{
LOG_WARN
(
"Failed to flush page %d of %d during purge page."
,
buf
->
page
.
page_num
,
buf
->
file_desc
);
LOG_WARN
(
"Failed to flush page %d of %d
(file desc)
during purge page."
,
buf
->
page
.
page_num
,
buf
->
file_desc
);
return
rc
;
return
rc
;
}
}
}
}
LOG_DEBUG
(
"Successfully purge frame =%p, page %d of %d"
,
buf
,
buf
->
page
.
page_num
,
buf
->
file_desc
);
LOG_DEBUG
(
"Successfully purge frame =%p, page %d of %d
(file desc)
"
,
buf
,
buf
->
page
.
page_num
,
buf
->
file_desc
);
bp_manager_
.
free
(
buf
);
bp_manager_
.
free
(
buf
);
return
RC
::
SUCCESS
;
return
RC
::
SUCCESS
;
}
}
...
@@ -533,7 +533,8 @@ RC DiskBufferPool::purge_all_pages(BPFileHandle *file_handle)
...
@@ -533,7 +533,8 @@ RC DiskBufferPool::purge_all_pages(BPFileHandle *file_handle)
for
(
std
::
list
<
Frame
*>::
iterator
it
=
used
.
begin
();
it
!=
used
.
end
();
++
it
)
{
for
(
std
::
list
<
Frame
*>::
iterator
it
=
used
.
begin
();
it
!=
used
.
end
();
++
it
)
{
Frame
*
frame
=
*
it
;
Frame
*
frame
=
*
it
;
if
(
frame
->
pin_count
>
0
)
{
if
(
frame
->
pin_count
>
0
)
{
LOG_WARN
(
"The page has been pinned, file_id:%d, pagenum:%d"
,
frame
->
file_desc
,
frame
->
page
.
page_num
);
LOG_WARN
(
"The page has been pinned, file_desc:%d, pagenum:%d, pin_count=%d"
,
frame
->
file_desc
,
frame
->
page
.
page_num
,
frame
->
pin_count
);
continue
;
continue
;
}
}
if
(
frame
->
dirty
)
{
if
(
frame
->
dirty
)
{
...
@@ -548,6 +549,29 @@ RC DiskBufferPool::purge_all_pages(BPFileHandle *file_handle)
...
@@ -548,6 +549,29 @@ RC DiskBufferPool::purge_all_pages(BPFileHandle *file_handle)
return
RC
::
SUCCESS
;
return
RC
::
SUCCESS
;
}
}
RC
DiskBufferPool
::
check_all_pages_unpinned
(
int
file_id
)
{
RC
rc
=
check_file_id
(
file_id
);
if
(
rc
!=
RC
::
SUCCESS
)
{
LOG_ERROR
(
"Failed to flush pages due to invalid file_id %d"
,
file_id
);
return
rc
;
}
BPFileHandle
*
file_handle
=
open_list_
[
file_id
];
std
::
list
<
Frame
*>
frames
=
bp_manager_
.
find_list
(
file_handle
->
file_desc
);
for
(
auto
&
frame
:
frames
)
{
if
(
frame
->
page
.
page_num
==
0
&&
frame
->
pin_count
>
1
)
{
LOG_WARN
(
"This page has been pinned. file id=%d, page num:%d, pin count=%d"
,
file_id
,
frame
->
page
.
page_num
,
frame
->
pin_count
);
}
else
if
(
frame
->
page
.
page_num
!=
0
&&
frame
->
pin_count
>
0
)
{
LOG_WARN
(
"This page has been pinned. file id=%d, page num:%d, pin count=%d"
,
file_id
,
frame
->
page
.
page_num
,
frame
->
pin_count
);
}
}
LOG_INFO
(
"all pages have been checked of file id %d"
,
file_id
);
return
RC
::
SUCCESS
;
}
RC
DiskBufferPool
::
flush_page
(
Frame
*
frame
)
RC
DiskBufferPool
::
flush_page
(
Frame
*
frame
)
{
{
// The better way is use mmap the block into memory,
// The better way is use mmap the block into memory,
...
...
src/observer/storage/default/disk_buffer_pool.h
浏览文件 @
02429ff7
...
@@ -69,6 +69,16 @@ typedef struct BPPageHandle {
...
@@ -69,6 +69,16 @@ typedef struct BPPageHandle {
BPPageHandle
()
:
open
(
false
),
frame
(
nullptr
)
BPPageHandle
()
:
open
(
false
),
frame
(
nullptr
)
{}
{}
PageNum
page_num
()
const
{
return
frame
->
page
.
page_num
;
}
void
mark_dirty
()
{
this
->
frame
->
dirty
=
true
;
}
char
*
data
()
{
return
this
->
frame
->
page
.
data
;
}
bool
open
;
bool
open
;
Frame
*
frame
;
Frame
*
frame
;
}
BPPageHandle
;
}
BPPageHandle
;
...
@@ -195,6 +205,8 @@ public:
...
@@ -195,6 +205,8 @@ public:
RC
purge_all_pages
(
int
file_id
);
RC
purge_all_pages
(
int
file_id
);
RC
check_all_pages_unpinned
(
int
file_id
);
protected:
protected:
RC
allocate_page
(
Frame
**
buf
);
RC
allocate_page
(
Frame
**
buf
);
...
...
unitest/bplus_tree_test.cpp
浏览文件 @
02429ff7
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录