Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
41a2b0e8
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
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看板
提交
41a2b0e8
编写于
11月 11, 2022
作者:
C
Cary Xu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
chore: append kv row to block data
上级
74223b34
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
48 addition
and
41 deletion
+48
-41
source/dnode/vnode/src/tsdb/tsdbUtil.c
source/dnode/vnode/src/tsdb/tsdbUtil.c
+48
-41
未找到文件。
source/dnode/vnode/src/tsdb/tsdbUtil.c
浏览文件 @
41a2b0e8
...
@@ -1058,6 +1058,7 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
...
@@ -1058,6 +1058,7 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
int32_t
iTColumn
=
1
;
int32_t
iTColumn
=
1
;
STColumn
*
pTColumn
=
(
iTColumn
<
pTSchema
->
numOfCols
)
?
&
pTSchema
->
columns
[
iTColumn
]
:
NULL
;
STColumn
*
pTColumn
=
(
iTColumn
<
pTSchema
->
numOfCols
)
?
&
pTSchema
->
columns
[
iTColumn
]
:
NULL
;
void
*
pBitmap
=
pRow
->
statis
?
tdGetBitmapAddrTp
(
pRow
,
pTSchema
->
flen
)
:
NULL
;
for
(
int32_t
iColData
=
0
;
iColData
<
pBlockData
->
nColData
;
iColData
++
)
{
for
(
int32_t
iColData
=
0
;
iColData
<
pBlockData
->
nColData
;
iColData
++
)
{
SColData
*
pColData
=
&
((
SColData
*
)
pBlockData
->
aColData
->
pData
)[
iColData
];
SColData
*
pColData
=
&
((
SColData
*
)
pBlockData
->
aColData
->
pData
)[
iColData
];
...
@@ -1076,8 +1077,8 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
...
@@ -1076,8 +1077,8 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
SColVal
cv
=
{.
cid
=
pTColumn
->
colId
,
.
type
=
pTColumn
->
type
};
SColVal
cv
=
{.
cid
=
pTColumn
->
colId
,
.
type
=
pTColumn
->
type
};
if
(
pRow
->
statis
)
{
if
(
pRow
->
statis
)
{
TDRowValT
vt
;
TDRowValT
vt
=
TD_VTYPE_MAX
;
tdGetBitmapValTypeII
(
tdGetBitmapAddrTp
(
pRow
,
pTSchema
->
flen
)
,
iTColumn
-
1
,
&
vt
);
tdGetBitmapValTypeII
(
pBitmap
,
iTColumn
-
1
,
&
vt
);
if
(
vt
==
TD_VTYPE_NORM
)
{
if
(
vt
==
TD_VTYPE_NORM
)
{
cv
.
flag
=
CV_FLAG_VALUE
;
cv
.
flag
=
CV_FLAG_VALUE
;
...
@@ -1128,6 +1129,10 @@ _exit:
...
@@ -1128,6 +1129,10 @@ _exit:
static
int32_t
tBlockDataAppendKVRow
(
SBlockData
*
pBlockData
,
STSRow
*
pRow
,
STSchema
*
pTSchema
)
{
static
int32_t
tBlockDataAppendKVRow
(
SBlockData
*
pBlockData
,
STSRow
*
pRow
,
STSchema
*
pTSchema
)
{
int32_t
code
=
0
;
int32_t
code
=
0
;
col_id_t
kvIter
=
0
;
col_id_t
nKvCols
=
tdRowGetNCols
(
pRow
)
-
1
;
void
*
pColIdx
=
TD_ROW_COL_IDX
(
pRow
);
void
*
pBitmap
=
tdGetBitmapAddrKv
(
pRow
,
tdRowGetNCols
(
pRow
));
int32_t
iTColumn
=
1
;
int32_t
iTColumn
=
1
;
STColumn
*
pTColumn
=
(
iTColumn
<
pTSchema
->
numOfCols
)
?
&
pTSchema
->
columns
[
iTColumn
]
:
NULL
;
STColumn
*
pTColumn
=
(
iTColumn
<
pTSchema
->
numOfCols
)
?
&
pTSchema
->
columns
[
iTColumn
]
:
NULL
;
...
@@ -1144,46 +1149,48 @@ static int32_t tBlockDataAppendKVRow(SBlockData *pBlockData, STSRow *pRow, STSch
...
@@ -1144,46 +1149,48 @@ static int32_t tBlockDataAppendKVRow(SBlockData *pBlockData, STSRow *pRow, STSch
if
(
code
)
goto
_exit
;
if
(
code
)
goto
_exit
;
}
else
{
}
else
{
ASSERT
(
pTColumn
->
type
==
pColData
->
type
);
ASSERT
(
pTColumn
->
type
==
pColData
->
type
);
ASSERT
(
pTColumn
->
colId
==
pColData
->
cid
);
SColVal
cv
=
{.
cid
=
pTColumn
->
colId
,
.
type
=
pTColumn
->
type
};
TDRowValT
vt
=
TD_VTYPE_NONE
;
// default is NONE
SKvRowIdx
*
pKvIdx
=
NULL
;
while
(
kvIter
<
nKvCols
)
{
pKvIdx
=
(
SKvRowIdx
*
)
POINTER_SHIFT
(
pColIdx
,
kvIter
*
sizeof
(
SKvRowIdx
));
if
(
pKvIdx
->
colId
==
pTColumn
->
colId
)
{
tdGetBitmapValTypeII
(
pBitmap
,
kvIter
,
&
vt
);
++
kvIter
;
break
;
}
else
if
(
pKvIdx
->
colId
>
pTColumn
->
colId
)
{
vt
=
TD_VTYPE_NONE
;
break
;
}
else
{
++
kvIter
;
}
}
if
(
vt
==
TD_VTYPE_NORM
)
{
cv
.
flag
=
CV_FLAG_VALUE
;
// SColVal cv = {.cid = pTColumn->colId, .type = pTColumn->type};
void
*
pData
=
POINTER_SHIFT
(
pRow
,
pKvIdx
->
offset
);
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
// if (pRow->statis) {
cv
.
value
.
nData
=
varDataLen
(
pData
);
// TDRowValT vt;
cv
.
value
.
pData
=
varDataVal
(
pData
);
// tdGetBitmapValTypeII(tdGetBitmapAddrTp(pRow, pTSchema->flen), iTColumn - 1, &vt);
}
else
{
memcpy
(
&
cv
.
value
.
val
,
pData
,
pTColumn
->
bytes
);
// if (vt == TD_VTYPE_NORM) {
}
// cv.flag = CV_FLAG_VALUE;
code
=
tColDataAppendValue
(
pColData
,
&
cv
);
// if (IS_VAR_DATA_TYPE(pTColumn->type)) {
if
(
code
)
goto
_exit
;
// void *pData = pRow->data + *(int32_t *)(pRow->data + pTColumn->offset);
}
else
if
(
vt
==
TD_VTYPE_NONE
)
{
// cv.value.nData = varDataLen(pData);
code
=
tColDataAppendValue
(
pColData
,
&
COL_VAL_NONE
(
pColData
->
cid
,
pColData
->
type
));
// cv.value.pData = varDataVal(pData);
if
(
code
)
goto
_exit
;
// } else {
}
else
if
(
vt
==
TD_VTYPE_NULL
)
{
// memcpy(&cv.value.val, pRow->data + pTColumn->offset, pTColumn->bytes);
code
=
tColDataAppendValue
(
pColData
,
&
COL_VAL_NULL
(
pColData
->
cid
,
pColData
->
type
));
// }
if
(
code
)
goto
_exit
;
}
else
{
// code = tColDataAppendValue(pColData, &cv);
ASSERT
(
0
);
// if (code) goto _exit;
}
// } else if (vt == TD_VTYPE_NONE) {
// code = tColDataAppendValue(pColData, &COL_VAL_NONE(pColData->cid, pColData->type));
// if (code) goto _exit;
// } else if (vt == TD_VTYPE_NULL) {
// code = tColDataAppendValue(pColData, &COL_VAL_NULL(pColData->cid, pColData->type));
// if (code) goto _exit;
// } else {
// ASSERT(0);
// }
// } else {
// cv.flag = CV_FLAG_VALUE;
// if (IS_VAR_DATA_TYPE(pTColumn->type)) {
// void *pData = pRow->data + *(int32_t *)(pRow->data + pTColumn->offset);
// cv.value.nData = varDataLen(pData);
// cv.value.pData = varDataVal(pData);
// } else {
// memcpy(&cv.value.val, pRow->data + pTColumn->offset, pT
// }
// }
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录