Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
53d4fe80
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看板
提交
53d4fe80
编写于
12月 06, 2021
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more
上级
2733f451
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
83 addition
and
16 deletion
+83
-16
source/dnode/vnode/meta/src/metaBDBImpl.c
source/dnode/vnode/meta/src/metaBDBImpl.c
+83
-16
未找到文件。
source/dnode/vnode/meta/src/metaBDBImpl.c
浏览文件 @
53d4fe80
...
...
@@ -18,7 +18,9 @@
#include "db.h"
struct
SMetaDB
{
DB
*
pDB
;
DB
*
pStbDB
;
DB
*
pCtbDB
;
DB
*
pNtbDB
;
DB
*
pIdx
;
DB_ENV
*
pEvn
;
};
...
...
@@ -32,22 +34,32 @@ int metaOpenDB(SMeta *pMeta) {
return
-
1
;
}
//
TODO:
create the env
// create the env
ret
=
db_env_create
(
&
(
pMeta
->
pDB
->
pEvn
),
0
);
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
// pMeta->pDB->pEvn->set_cachesize(pMeta->pDB->pEvn, )
ret
=
pMeta
->
pDB
->
pEvn
->
open
(
pMeta
->
pDB
->
pEvn
,
pMeta
->
path
,
DB_CREATE
|
DB_INIT_MPOOL
,
0
);
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
ret
=
db_create
(
&
(
pMeta
->
pDB
->
pDB
),
pMeta
->
pDB
->
pEvn
,
0
);
ret
=
db_create
(
&
(
pMeta
->
pDB
->
pStbDB
),
pMeta
->
pDB
->
pEvn
,
0
);
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
ret
=
db_create
(
&
(
pMeta
->
pDB
->
pCtbDB
),
pMeta
->
pDB
->
pEvn
,
0
);
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
ret
=
db_create
(
&
(
pMeta
->
pDB
->
pNtbDB
),
pMeta
->
pDB
->
pEvn
,
0
);
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
...
...
@@ -59,13 +71,37 @@ int metaOpenDB(SMeta *pMeta) {
return
-
1
;
}
ret
=
pMeta
->
pDB
->
pDB
->
open
(
pMeta
->
pDB
->
pDB
,
/* DB structure pointer */
NULL
,
/* Transaction pointer */
"meta.db"
,
/* On-disk file that holds the database */
NULL
,
/* Optional logical database name */
DB_BTREE
,
/* Database access method */
DB_CREATE
,
/* Open flags */
0
);
/* File mode */
ret
=
pMeta
->
pDB
->
pStbDB
->
open
(
pMeta
->
pDB
->
pStbDB
,
/* DB structure pointer */
NULL
,
/* Transaction pointer */
"meta.db"
,
/* On-disk file that holds the database */
NULL
,
/* Optional logical database name */
DB_BTREE
,
/* Database access method */
DB_CREATE
,
/* Open flags */
0
);
/* File mode */
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
ret
=
pMeta
->
pDB
->
pCtbDB
->
open
(
pMeta
->
pDB
->
pCtbDB
,
/* DB structure pointer */
NULL
,
/* Transaction pointer */
"meta.db"
,
/* On-disk file that holds the database */
NULL
,
/* Optional logical database name */
DB_BTREE
,
/* Database access method */
DB_CREATE
,
/* Open flags */
0
);
/* File mode */
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
}
ret
=
pMeta
->
pDB
->
pNtbDB
->
open
(
pMeta
->
pDB
->
pNtbDB
,
/* DB structure pointer */
NULL
,
/* Transaction pointer */
"meta.db"
,
/* On-disk file that holds the database */
NULL
,
/* Optional logical database name */
DB_BTREE
,
/* Database access method */
DB_CREATE
,
/* Open flags */
0
);
/* File mode */
if
(
ret
!=
0
)
{
// TODO: handle error
return
-
1
;
...
...
@@ -94,9 +130,19 @@ void metaCloseDB(SMeta *pMeta) {
pMeta
->
pDB
->
pIdx
=
NULL
;
}
if
(
pMeta
->
pDB
->
pDB
)
{
pMeta
->
pDB
->
pDB
->
close
(
pMeta
->
pDB
->
pDB
,
0
);
pMeta
->
pDB
->
pDB
=
NULL
;
if
(
pMeta
->
pDB
->
pNtbDB
)
{
pMeta
->
pDB
->
pNtbDB
->
close
(
pMeta
->
pDB
->
pNtbDB
,
0
);
pMeta
->
pDB
->
pNtbDB
=
NULL
;
}
if
(
pMeta
->
pDB
->
pCtbDB
)
{
pMeta
->
pDB
->
pCtbDB
->
close
(
pMeta
->
pDB
->
pCtbDB
,
0
);
pMeta
->
pDB
->
pCtbDB
=
NULL
;
}
if
(
pMeta
->
pDB
->
pStbDB
)
{
pMeta
->
pDB
->
pStbDB
->
close
(
pMeta
->
pDB
->
pStbDB
,
0
);
pMeta
->
pDB
->
pStbDB
=
NULL
;
}
if
(
pMeta
->
pDB
->
pEvn
)
{
...
...
@@ -109,7 +155,28 @@ void metaCloseDB(SMeta *pMeta) {
}
int
metaSaveTableToDB
(
SMeta
*
pMeta
,
const
STbCfg
*
pTbCfg
)
{
// TODO
tb_uid_t
uid
;
DBT
key
=
{
0
};
DBT
value
=
{
0
};
char
buf
[
256
];
void
*
pBuf
;
int
bsize
;
if
(
pTbCfg
->
type
==
META_SUPER_TABLE
)
{
uid
=
pTbCfg
->
stbCfg
.
suid
;
}
else
{
uid
=
metaGenerateUid
(
pMeta
);
}
key
.
size
=
sizeof
(
uid
);
key
.
data
=
&
uid
;
pBuf
=
buf
;
value
.
size
=
metaEncodeTbCfg
(
&
pBuf
,
pTbCfg
);
value
.
data
=
buf
;
pMeta
->
pDB
->
pStbDB
->
put
(
pMeta
->
pDB
->
pStbDB
,
NULL
,
&
key
,
&
value
,
0
);
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录