Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
dc2d5e36
T
TDengine
项目概览
taosdata
/
TDengine
大约 1 年 前同步成功
通知
1184
Star
22015
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
dc2d5e36
编写于
11月 21, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more code
上级
78c57042
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
91 addition
and
11 deletion
+91
-11
include/common/tdataformat.h
include/common/tdataformat.h
+1
-1
source/common/src/tdataformat.c
source/common/src/tdataformat.c
+90
-10
未找到文件。
include/common/tdataformat.h
浏览文件 @
dc2d5e36
...
...
@@ -88,7 +88,7 @@ void tTSchemaDestroy(STSchema *pTSchema);
#define COL_VAL_IS_VALUE(CV) ((CV)->flag == CV_FLAG_VALUE)
// SRow ================================
int32_t
tRow
Put
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
);
int32_t
tRow
Build
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
);
void
tRowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
int32_t
tRowToArr
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SArray
**
aColValP
);
...
...
source/common/src/tdataformat.c
浏览文件 @
dc2d5e36
...
...
@@ -58,7 +58,7 @@ typedef struct {
uint8_t
idx
[];
}
SKVIdx
;
int32_t
tRow
Put
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
)
{
int32_t
tRow
Build
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
)
{
int32_t
code
=
0
;
ASSERT
(
taosArrayGetSize
(
aColVal
)
>
0
);
...
...
@@ -153,7 +153,7 @@ int32_t tRowPut(SArray *aColVal, STSchema *pTSchema, SBuffer *pBuffer) {
}
// alloc --------------
SRow
*
pRow
=
NULL
;
SRow
*
pRow
=
NULL
;
// todo
// build --------------
pColVal
=
(
SColVal
*
)
taosArrayGet
(
aColVal
,
0
);
...
...
@@ -202,17 +202,32 @@ int32_t tRowPut(SArray *aColVal, STSchema *pTSchema, SBuffer *pBuffer) {
}
else
{
// TUPLE
uint8_t
*
pb
=
NULL
;
uint8_t
*
pf
=
NULL
;
uint8_t
*
pv
=
NULL
;
// todo
uint8_t
*
pv
=
NULL
;
int32_t
nv
=
0
;
// todo
// build impl
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
// todo
// set bit map
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
*
(
int32_t
*
)(
pf
+
pTColumn
->
offset
)
=
nv
;
nv
+=
tPutU32v
(
pv
+
nv
,
pColVal
->
value
.
nData
);
if
(
pColVal
->
value
.
nData
)
{
memcpy
(
pv
+
nv
,
pColVal
->
value
.
pData
,
pColVal
->
value
.
nData
);
nv
+=
pColVal
->
value
.
nData
;
}
}
else
{
memcpy
(
pf
+
pTColumn
->
offset
,
&
pColVal
->
value
.
val
,
TYPE_BYTES
[
pTColumn
->
type
]);
}
}
else
if
(
COL_VAL_IS_NONE
(
pColVal
))
{
//
todo
//
set bitmap
}
else
{
//
todo
//
set bitmap
}
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
...
...
@@ -223,6 +238,7 @@ int32_t tRowPut(SArray *aColVal, STSchema *pTSchema, SBuffer *pBuffer) {
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
// set bitmap
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
...
...
@@ -457,15 +473,79 @@ _exit:
}
void
tRowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
)
{
ASSERT
(
iCol
<
pTSchema
->
numOfCols
);
STColumn
*
pTColumn
=
pTSchema
->
columns
+
iCol
;
if
(
pRow
->
flag
&
ROW_FLG_KV
)
{
// tuple row
// todo
}
else
{
// kv row
// todo
if
(
iCol
==
0
)
{
pColVal
->
cid
=
pTColumn
->
colId
;
pColVal
->
type
=
pTColumn
->
type
;
pColVal
->
flag
=
CV_FLAG_VALUE
;
memcpy
(
&
pColVal
->
value
.
val
,
&
pRow
->
ts
,
sizeof
(
TSKEY
));
return
;
}
if
(
pRow
->
flag
==
HAS_NONE
)
{
*
pColVal
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
}
if
(
pRow
->
flag
==
HAS_NULL
)
{
*
pColVal
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
}
if
(
pRow
->
flag
&
ROW_FLG_KV
)
{
// KV Row
SKVIdx
*
pIdx
=
(
SKVIdx
*
)
pRow
->
data
;
uint8_t
*
pv
=
pRow
->
data
+
sizeof
(
*
pIdx
)
+
sizeof
(
int32_t
)
*
pIdx
->
nidx
;
int16_t
lidx
=
0
;
int16_t
ridx
=
pIdx
->
nidx
-
1
;
while
(
lidx
<=
ridx
)
{
int16_t
mid
=
(
lidx
+
ridx
)
>>
1
;
uint8_t
*
pData
=
pv
+
pIdx
->
idx
[
mid
];
// todo
int16_t
cid
=
0
;
pData
+=
tGetI16v
(
pData
,
&
cid
);
if
(
TABS
(
cid
)
==
pTColumn
->
colId
)
{
if
(
cid
<
0
)
{
*
pColVal
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
}
else
{
pColVal
->
cid
=
pTColumn
->
colId
;
pColVal
->
type
=
pTColumn
->
type
;
pColVal
->
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
pData
+=
tGetU32v
(
pData
,
&
pColVal
->
value
.
nData
);
if
(
pColVal
->
value
.
nData
>
0
)
{
pColVal
->
value
.
pData
=
pData
;
}
else
{
pColVal
->
value
.
pData
=
NULL
;
}
}
else
{
memcpy
(
&
pColVal
->
value
.
val
,
pData
,
pTColumn
->
bytes
);
}
}
return
;
}
else
if
(
TABS
(
cid
)
<
pTColumn
->
colId
)
{
lidx
=
mid
+
1
;
}
else
{
ridx
=
mid
-
1
;
}
}
*
pColVal
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
}
else
{
// Tuple Row
if
(
pRow
->
flag
==
HAS_VALUE
)
{
}
else
{
// todo
}
}
}
int32_t
tRowToArr
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SArray
**
aColValP
)
{
return
0
;
}
#if 0
static void setBitMap(uint8_t *pb, uint8_t v, int32_t idx, uint8_t flags) {
if (pb) {
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录