Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
f51c8643
TDengine
项目概览
taosdata
/
TDengine
大约 1 年 前同步成功
通知
1184
Star
22015
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
f51c8643
编写于
9月 21, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more code
上级
b9a248d7
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
124 addition
and
74 deletion
+124
-74
source/dnode/vnode/src/tsdb/tsdbDiskData.c
source/dnode/vnode/src/tsdb/tsdbDiskData.c
+124
-74
未找到文件。
source/dnode/vnode/src/tsdb/tsdbDiskData.c
浏览文件 @
f51c8643
...
...
@@ -15,8 +15,9 @@
#include "tsdb.h"
typedef
struct
SDiskData
SDiskData
;
typedef
struct
SDiskCol
SDiskCol
;
typedef
struct
SDiskDataBuilder
SDiskDataBuilder
;
typedef
struct
SDiskCol
SDiskCol
;
typedef
struct
SDiskData
SDiskData
;
struct
SDiskCol
{
int16_t
cid
;
...
...
@@ -70,6 +71,34 @@ static int32_t tDiskColClear(SDiskCol *pDiskCol) {
return
code
;
}
static
int32_t
tDiskColToBinary
(
SDiskCol
*
pDiskCol
,
const
uint8_t
**
ppData
,
int32_t
*
nData
)
{
int32_t
code
=
0
;
ASSERT
(
pDiskCol
->
flag
&&
pDiskCol
->
flag
!=
HAS_NONE
);
if
(
pDiskCol
->
flag
==
HAS_NULL
)
{
return
code
;
}
// bitmap (todo)
if
(
pDiskCol
->
flag
!=
HAS_VALUE
)
{
}
// offset (todo)
if
(
IS_VAR_DATA_TYPE
(
pDiskCol
->
type
))
{
code
=
tCompGen
(
pDiskCol
->
pOffC
,
NULL
/* todo */
,
NULL
/* todo */
);
if
(
code
)
return
code
;
}
// value (todo)
if
(
pDiskCol
->
flag
!=
(
HAS_NULL
|
HAS_NONE
))
{
code
=
tCompGen
(
pDiskCol
->
pValC
,
NULL
/* todo */
,
NULL
/* todo */
);
if
(
code
)
return
code
;
}
return
code
;
}
static
int32_t
tDiskColAddValue
(
SDiskCol
*
pDiskCol
,
SColVal
*
pColVal
)
{
int32_t
code
=
0
;
...
...
@@ -338,8 +367,8 @@ static int32_t (*tDiskColAddValImpl[])(SDiskCol *pDiskCol, SColVal *pColVal) = {
tDiskColAddVal7
,
// HAS_VALUE|HAS_NULL|HAS_NONE
};
// SDiskData ================================================
struct
SDiskData
{
// SDiskData
Builder
================================================
struct
SDiskData
Builder
{
int64_t
suid
;
int64_t
uid
;
int32_t
nRow
;
...
...
@@ -352,121 +381,121 @@ struct SDiskData {
uint8_t
*
aBuf
[
2
];
};
int32_t
tDiskData
Init
(
SDiskData
*
pDiskData
,
STSchema
*
pTSchema
,
TABLEID
*
pId
,
uint8_t
cmprAlg
)
{
int32_t
tDiskData
BuilderInit
(
SDiskDataBuilder
*
pBuilder
,
STSchema
*
pTSchema
,
TABLEID
*
pId
,
uint8_t
cmprAlg
)
{
int32_t
code
=
0
;
p
DiskData
->
suid
=
pId
->
suid
;
p
DiskData
->
uid
=
pId
->
uid
;
p
DiskData
->
nRow
=
0
;
p
DiskData
->
cmprAlg
=
cmprAlg
;
p
Builder
->
suid
=
pId
->
suid
;
p
Builder
->
uid
=
pId
->
uid
;
p
Builder
->
nRow
=
0
;
p
Builder
->
cmprAlg
=
cmprAlg
;
if
(
p
DiskData
->
pUidC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
DiskData
->
pUidC
);
if
(
p
Builder
->
pUidC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
Builder
->
pUidC
);
if
(
code
)
return
code
;
}
code
=
tCompressorReset
(
p
DiskData
->
pUidC
,
TSDB_DATA_TYPE_BIGINT
,
cmprAlg
);
code
=
tCompressorReset
(
p
Builder
->
pUidC
,
TSDB_DATA_TYPE_BIGINT
,
cmprAlg
);
if
(
code
)
return
code
;
if
(
p
DiskData
->
pVerC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
DiskData
->
pVerC
);
if
(
p
Builder
->
pVerC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
Builder
->
pVerC
);
if
(
code
)
return
code
;
}
code
=
tCompressorReset
(
p
DiskData
->
pVerC
,
TSDB_DATA_TYPE_BIGINT
,
cmprAlg
);
code
=
tCompressorReset
(
p
Builder
->
pVerC
,
TSDB_DATA_TYPE_BIGINT
,
cmprAlg
);
if
(
code
)
return
code
;
if
(
p
DiskData
->
pKeyC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
DiskData
->
pKeyC
);
if
(
p
Builder
->
pKeyC
==
NULL
)
{
code
=
tCompressorCreate
(
&
p
Builder
->
pKeyC
);
if
(
code
)
return
code
;
}
code
=
tCompressorReset
(
p
DiskData
->
pKeyC
,
TSDB_DATA_TYPE_TIMESTAMP
,
cmprAlg
);
code
=
tCompressorReset
(
p
Builder
->
pKeyC
,
TSDB_DATA_TYPE_TIMESTAMP
,
cmprAlg
);
if
(
code
)
return
code
;
if
(
p
DiskData
->
aDiskCol
==
NULL
)
{
p
DiskData
->
aDiskCol
=
taosArrayInit
(
pTSchema
->
numOfCols
-
1
,
sizeof
(
SDiskCol
));
if
(
p
DiskData
->
aDiskCol
==
NULL
)
{
if
(
p
Builder
->
aDiskCol
==
NULL
)
{
p
Builder
->
aDiskCol
=
taosArrayInit
(
pTSchema
->
numOfCols
-
1
,
sizeof
(
SDiskCol
));
if
(
p
Builder
->
aDiskCol
==
NULL
)
{
code
=
TSDB_CODE_OUT_OF_MEMORY
;
return
code
;
}
}
p
DiskData
->
nDiskCol
=
0
;
p
Builder
->
nDiskCol
=
0
;
for
(
int32_t
iCol
=
1
;
iCol
<
pTSchema
->
numOfCols
;
iCol
++
)
{
STColumn
*
pTColumn
=
&
pTSchema
->
columns
[
iCol
];
if
(
p
DiskData
->
nDiskCol
>=
taosArrayGetSize
(
pDiskData
->
aDiskCol
))
{
if
(
p
Builder
->
nDiskCol
>=
taosArrayGetSize
(
pBuilder
->
aDiskCol
))
{
SDiskCol
dc
=
(
SDiskCol
){
0
};
if
(
taosArrayPush
(
p
DiskData
->
aDiskCol
,
&
dc
)
==
NULL
)
{
if
(
taosArrayPush
(
p
Builder
->
aDiskCol
,
&
dc
)
==
NULL
)
{
code
=
TSDB_CODE_OUT_OF_MEMORY
;
return
code
;
}
}
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
pDiskData
->
nDiskCol
);
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
Builder
->
aDiskCol
,
pBuilder
->
nDiskCol
);
code
=
tDiskColInit
(
pDiskCol
,
pTColumn
->
colId
,
pTColumn
->
type
,
cmprAlg
);
if
(
code
)
return
code
;
p
DiskData
->
nDiskCol
++
;
p
Builder
->
nDiskCol
++
;
}
return
code
;
}
int32_t
tDiskData
Destroy
(
SDiskData
*
pDiskData
)
{
int32_t
tDiskData
BuilderDestroy
(
SDiskDataBuilder
*
pBuilder
)
{
int32_t
code
=
0
;
if
(
p
DiskData
->
pUidC
)
tCompressorDestroy
(
pDiskData
->
pUidC
);
if
(
p
DiskData
->
pVerC
)
tCompressorDestroy
(
pDiskData
->
pVerC
);
if
(
p
DiskData
->
pKeyC
)
tCompressorDestroy
(
pDiskData
->
pKeyC
);
if
(
p
Builder
->
pUidC
)
tCompressorDestroy
(
pBuilder
->
pUidC
);
if
(
p
Builder
->
pVerC
)
tCompressorDestroy
(
pBuilder
->
pVerC
);
if
(
p
Builder
->
pKeyC
)
tCompressorDestroy
(
pBuilder
->
pKeyC
);
if
(
p
DiskData
->
aDiskCol
)
{
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
taosArrayGetSize
(
p
DiskData
->
aDiskCol
);
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
iDiskCol
);
if
(
p
Builder
->
aDiskCol
)
{
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
taosArrayGetSize
(
p
Builder
->
aDiskCol
);
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
Builder
->
aDiskCol
,
iDiskCol
);
tDiskColClear
(
pDiskCol
);
}
taosArrayDestroy
(
p
DiskData
->
aDiskCol
);
taosArrayDestroy
(
p
Builder
->
aDiskCol
);
}
for
(
int32_t
iBuf
=
0
;
iBuf
<
sizeof
(
p
DiskData
->
aBuf
)
/
sizeof
(
pDiskData
->
aBuf
[
0
]);
iBuf
++
)
{
tFree
(
p
DiskData
->
aBuf
[
iBuf
]);
for
(
int32_t
iBuf
=
0
;
iBuf
<
sizeof
(
p
Builder
->
aBuf
)
/
sizeof
(
pBuilder
->
aBuf
[
0
]);
iBuf
++
)
{
tFree
(
p
Builder
->
aBuf
[
iBuf
]);
}
return
code
;
}
int32_t
tDiskData
AddRow
(
SDiskData
*
pDiskData
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
,
TABLEID
*
pId
)
{
int32_t
tDiskData
BuilderAddRow
(
SDiskDataBuilder
*
pBuilder
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
,
TABLEID
*
pId
)
{
int32_t
code
=
0
;
ASSERT
(
pId
->
suid
==
p
DiskData
->
suid
);
ASSERT
(
pId
->
suid
==
p
Builder
->
suid
);
// uid
if
(
p
DiskData
->
uid
&&
pDiskData
->
uid
!=
pId
->
uid
)
{
for
(
int32_t
iRow
=
0
;
iRow
<
p
DiskData
->
nRow
;
iRow
++
)
{
code
=
tCompress
(
p
DiskData
->
pUidC
,
&
pDiskData
->
uid
,
sizeof
(
int64_t
));
if
(
p
Builder
->
uid
&&
pBuilder
->
uid
!=
pId
->
uid
)
{
for
(
int32_t
iRow
=
0
;
iRow
<
p
Builder
->
nRow
;
iRow
++
)
{
code
=
tCompress
(
p
Builder
->
pUidC
,
&
pBuilder
->
uid
,
sizeof
(
int64_t
));
if
(
code
)
goto
_exit
;
}
p
DiskData
->
uid
=
0
;
p
Builder
->
uid
=
0
;
}
if
(
p
DiskData
->
uid
==
0
)
{
code
=
tCompress
(
p
DiskData
->
pUidC
,
&
pId
->
uid
,
sizeof
(
int64_t
));
if
(
p
Builder
->
uid
==
0
)
{
code
=
tCompress
(
p
Builder
->
pUidC
,
&
pId
->
uid
,
sizeof
(
int64_t
));
if
(
code
)
goto
_exit
;
}
// version
int64_t
version
=
TSDBROW_VERSION
(
pRow
);
code
=
tCompress
(
p
DiskData
->
pVerC
,
&
version
,
sizeof
(
int64_t
));
code
=
tCompress
(
p
Builder
->
pVerC
,
&
version
,
sizeof
(
int64_t
));
if
(
code
)
goto
_exit
;
// TSKEY
TSKEY
ts
=
TSDBROW_TS
(
pRow
);
code
=
tCompress
(
p
DiskData
->
pKeyC
,
&
ts
,
sizeof
(
int64_t
));
code
=
tCompress
(
p
Builder
->
pKeyC
,
&
ts
,
sizeof
(
int64_t
));
if
(
code
)
goto
_exit
;
SRowIter
iter
=
{
0
};
tRowIterInit
(
&
iter
,
pRow
,
pTSchema
);
SColVal
*
pColVal
=
tRowIterNext
(
&
iter
);
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
DiskData
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
iDiskCol
);
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
Builder
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
Builder
->
aDiskCol
,
iDiskCol
);
while
(
pColVal
&&
pColVal
->
cid
<
pDiskCol
->
cid
)
{
pColVal
=
tRowIterNext
(
&
iter
);
...
...
@@ -482,53 +511,53 @@ int32_t tDiskDataAddRow(SDiskData *pDiskData, TSDBROW *pRow, STSchema *pTSchema,
pColVal
=
tRowIterNext
(
&
iter
);
}
}
p
DiskData
->
nRow
++
;
p
Builder
->
nRow
++
;
_exit:
return
code
;
}
int32_t
t
DiskDataToBinary
(
SDiskData
*
pDiskData
,
const
uint8_t
**
ppData
,
int32_t
*
n
Data
)
{
int32_t
t
GnrtDiskData
(
SDiskDataBuilder
*
pBuilder
,
SDiskData
*
pDisk
Data
)
{
int32_t
code
=
0
;
ASSERT
(
p
DiskData
->
nRow
);
ASSERT
(
p
Builder
->
nRow
);
SDiskDataHdr
hdr
=
{.
delimiter
=
TSDB_FILE_DLMT
,
.
fmtVer
=
0
,
.
suid
=
p
DiskData
->
suid
,
.
uid
=
p
DiskData
->
uid
,
.
suid
=
p
Builder
->
suid
,
.
uid
=
p
Builder
->
uid
,
.
szUid
=
0
,
.
szVer
=
0
,
.
szKey
=
0
,
.
szBlkCol
=
0
,
.
nRow
=
p
DiskData
->
nRow
,
.
cmprAlg
=
p
DiskData
->
cmprAlg
};
.
nRow
=
p
Builder
->
nRow
,
.
cmprAlg
=
p
Builder
->
cmprAlg
};
// UID
const
uint8_t
*
pUid
=
NULL
;
if
(
p
DiskData
->
uid
==
0
)
{
code
=
tCompGen
(
p
DiskData
->
pUidC
,
&
pUid
,
&
hdr
.
szUid
);
if
(
p
Builder
->
uid
==
0
)
{
code
=
tCompGen
(
p
Builder
->
pUidC
,
&
pUid
,
&
hdr
.
szUid
);
if
(
code
)
return
code
;
}
// VERSION
const
uint8_t
*
pVer
=
NULL
;
code
=
tCompGen
(
p
DiskData
->
pVerC
,
&
pVer
,
&
hdr
.
szVer
);
code
=
tCompGen
(
p
Builder
->
pVerC
,
&
pVer
,
&
hdr
.
szVer
);
if
(
code
)
return
code
;
// TSKEY
const
uint8_t
*
pKey
=
NULL
;
code
=
tCompGen
(
p
DiskData
->
pKeyC
,
&
pKey
,
&
hdr
.
szKey
);
code
=
tCompGen
(
p
Builder
->
pKeyC
,
&
pKey
,
&
hdr
.
szKey
);
if
(
code
)
return
code
;
int32_t
offset
=
0
;
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
DiskData
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
iDiskCol
);
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
Builder
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
Builder
->
aDiskCol
,
iDiskCol
);
if
(
pDiskCol
->
flag
==
HAS_NONE
)
continue
;
// code = tDiskColToBinary(pDiskCol,
);
//
if (code) return code;
code
=
tDiskColToBinary
(
pDiskCol
,
NULL
,
NULL
);
if
(
code
)
return
code
;
SBlockCol
bCol
=
{.
cid
=
pDiskCol
->
cid
,
.
type
=
pDiskCol
->
type
,
...
...
@@ -544,30 +573,51 @@ int32_t tDiskDataToBinary(SDiskData *pDiskData, const uint8_t **ppData, int32_t
offset
=
offset
+
bCol
.
szBitmap
+
bCol
.
szOffset
+
bCol
.
szValue
;
}
#if 0
*nData = tPutDiskDataHdr(NULL, &hdr) + hdr.szUid + hdr.szVer + hdr.szKey + hdr.szBlkCol + offset;
code
=
tRealloc
(
&
p
DiskData
->
aBuf
[
0
],
*
nData
);
code = tRealloc(&p
Builder
->aBuf[0], *nData);
if (code) return code;
*
ppData
=
p
DiskData
->
aBuf
[
0
];
*ppData = p
Builder
->aBuf[0];
int32_t n = 0;
n
+=
tPutDiskDataHdr
(
p
DiskData
->
aBuf
[
0
]
+
n
,
&
hdr
);
n += tPutDiskDataHdr(p
Builder
->aBuf[0] + n, &hdr);
if (hdr.szUid) {
memcpy
(
p
DiskData
->
aBuf
[
0
]
+
n
,
pUid
,
hdr
.
szUid
);
memcpy(p
Builder
->aBuf[0] + n, pUid, hdr.szUid);
n += hdr.szUid;
}
memcpy
(
p
DiskData
->
aBuf
[
0
]
+
n
,
pVer
,
hdr
.
szVer
);
memcpy(p
Builder
->aBuf[0] + n, pVer, hdr.szVer);
n += hdr.szVer;
memcpy
(
p
DiskData
->
aBuf
[
0
]
+
n
,
pKey
,
hdr
.
szKey
);
memcpy(p
Builder
->aBuf[0] + n, pKey, hdr.szKey);
n += hdr.szKey;
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
DiskData
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
iDiskCol
);
n
+=
tPutBlockCol
(
p
DiskData
->
aBuf
[
0
]
+
n
,
NULL
/*pDiskCol->bCol (todo) */
);
for (int32_t iDiskCol = 0; iDiskCol < p
Builder
->nDiskCol; iDiskCol++) {
SDiskCol *pDiskCol = (SDiskCol *)taosArrayGet(p
Builder
->aDiskCol, iDiskCol);
n += tPutBlockCol(p
Builder
->aBuf[0] + n, NULL /*pDiskCol->bCol (todo) */);
}
for
(
int32_t
iDiskCol
=
0
;
iDiskCol
<
p
DiskData
->
nDiskCol
;
iDiskCol
++
)
{
SDiskCol
*
pDiskCol
=
(
SDiskCol
*
)
taosArrayGet
(
p
DiskData
->
aDiskCol
,
iDiskCol
);
for (int32_t iDiskCol = 0; iDiskCol < p
Builder
->nDiskCol; iDiskCol++) {
SDiskCol *pDiskCol = (SDiskCol *)taosArrayGet(p
Builder
->aDiskCol, iDiskCol);
// memcpy(pDiskData->aBuf[0] + n, NULL, );
// n += 0;
}
#endif
return
code
;
}
// SDiskData ================================================
struct
SDiskData
{
SDiskDataHdr
hdr
;
const
uint8_t
*
pUid
;
const
uint8_t
*
pVer
;
const
uint8_t
*
pKey
;
SArray
*
aBlockCol
;
SArray
*
aColData
;
};
int32_t
tDiskDataDestroy
(
SDiskData
*
pDiskData
)
{
int32_t
code
=
0
;
if
(
pDiskData
->
aBlockCol
)
taosArrayDestroy
(
pDiskData
->
aBlockCol
);
if
(
pDiskData
->
aColData
)
taosArrayDestroy
(
pDiskData
->
aColData
);
return
code
;
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录