Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
1075c230
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1187
Star
22018
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
1075c230
编写于
3月 21, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more TDB
上级
b3b52985
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
29 addition
and
11 deletion
+29
-11
source/libs/tdb/src/db/tdbBtree.c
source/libs/tdb/src/db/tdbBtree.c
+27
-10
source/libs/tdb/src/inc/tdbPage.h
source/libs/tdb/src/inc/tdbPage.h
+2
-1
未找到文件。
source/libs/tdb/src/db/tdbBtree.c
浏览文件 @
1075c230
...
...
@@ -644,19 +644,11 @@ static int tdbBtreeBalanceStep6(SBtreeBalanceHelper *pBlh) {
static
int
tdbBtreeBalanceNonRoot
(
SBTree
*
pBt
,
SPage
*
pParent
,
int
idx
)
{
int
ret
;
#if 0
SBtreeBalanceHelper blh;
blh.pBt = pBt;
blh.pParent = pParent;
blh.idx = idx;
#endif
int
nOlds
;
SPage
*
pOlds
[
3
];
{
// Find 3 child pages at most to do balance
{
// Find 3 child pages at most to do balance
int
nCells
=
TDB_PAGE_TOTAL_CELLS
(
pParent
);
int
sIdx
;
if
(
nCells
<=
2
)
{
...
...
@@ -695,7 +687,32 @@ static int tdbBtreeBalanceNonRoot(SBTree *pBt, SPage *pParent, int idx) {
}
}
// >>>>>>>>>>>>>>>>>>>
int
nNews
=
0
;
int
cntNews
[
5
]
=
{
0
};
// TODO: maybe 5 is not enough
int
szNews
[
5
]
=
{
0
};
int
maxPageCapacity
;
// TODO
{
// Get how many new pages are needed and the new distribution
// loop to find number of pages needed
for
(
int
i
=
0
;
i
<
nOlds
;
i
++
)
{
SPage
*
pPage
=
pOlds
[
i
];
SCell
*
pCell
;
int
cellBytes
;
for
(
int
cIdx
=
0
;
cIdx
<
TDB_PAGE_TOTAL_CELLS
(
pPage
);
cIdx
++
)
{
pCell
=
tdbPageGetCell
(
pPage
,
cIdx
);
cellBytes
=
TDB_BYTES_CELL_TAKEN
(
pPage
,
pCell
);
if
(
szNews
[
nNews
]
+
cellBytes
>
maxPageCapacity
)
{
nNews
++
;
}
cntNews
[
nNews
]
++
;
szNews
[
nNews
]
=
szNews
[
nNews
]
+
cellBytes
;
}
}
// Loop to make the distribution even
}
#if 0
// Step 1: find two sibling pages and get engough info about the old pages
...
...
source/libs/tdb/src/inc/tdbPage.h
浏览文件 @
1075c230
...
...
@@ -98,7 +98,8 @@ struct SPage {
})
// APIs
#define TDB_PAGE_TOTAL_CELLS(pPage) ((pPage)->nOverflow + (pPage)->pPageMethods->getCellNum(pPage))
#define TDB_PAGE_TOTAL_CELLS(pPage) ((pPage)->nOverflow + (pPage)->pPageMethods->getCellNum(pPage))
#define TDB_BYTES_CELL_TAKEN(pPage, pCell) ((*(pPage)->xCellSize)(pPage, pCell) + (pPage)->pPageMethods->szOffset)
int
tdbPageCreate
(
int
pageSize
,
SPage
**
ppPage
,
void
*
(
*
xMalloc
)(
void
*
,
size_t
),
void
*
arg
);
int
tdbPageDestroy
(
SPage
*
pPage
,
void
(
*
xFree
)(
void
*
arg
,
void
*
ptr
),
void
*
arg
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录