Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
e69821a6
T
TDengine
项目概览
taosdata
/
TDengine
大约 2 年 前同步成功
通知
1193
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看板
提交
e69821a6
编写于
11月 20, 2022
作者:
H
Hongze Cheng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
more code
上级
2b68b919
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
79 addition
and
30 deletion
+79
-30
include/common/tdataformat.h
include/common/tdataformat.h
+3
-3
source/common/src/tdataformat.c
source/common/src/tdataformat.c
+76
-27
未找到文件。
include/common/tdataformat.h
浏览文件 @
e69821a6
...
@@ -88,9 +88,9 @@ void tTSchemaDestroy(STSchema *pTSchema);
...
@@ -88,9 +88,9 @@ void tTSchemaDestroy(STSchema *pTSchema);
#define COL_VAL_IS_VALUE(CV) ((CV)->flag == CV_FLAG_VALUE)
#define COL_VAL_IS_VALUE(CV) ((CV)->flag == CV_FLAG_VALUE)
// SRow ================================
// SRow ================================
int32_t
t
TS
RowPut
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
);
int32_t
tRowPut
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
);
void
t
TS
RowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
void
tRowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
int32_t
t
TSRowToArray
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SArray
**
ppArray
);
int32_t
t
RowToArr
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SArray
**
aColValP
);
// SRowIter ================================
// SRowIter ================================
...
...
source/common/src/tdataformat.c
浏览文件 @
e69821a6
...
@@ -46,37 +46,56 @@ int32_t tBufferPut(SBuffer *pBuffer, const void *pData, int64_t nData) {
...
@@ -46,37 +46,56 @@ int32_t tBufferPut(SBuffer *pBuffer, const void *pData, int64_t nData) {
// ================================
// ================================
static
int32_t
tGetTagVal
(
uint8_t
*
p
,
STagVal
*
pTagVal
,
int8_t
isJson
);
static
int32_t
tGetTagVal
(
uint8_t
*
p
,
STagVal
*
pTagVal
,
int8_t
isJson
);
#pragma pack(push, 1)
typedef
struct
{
int16_t
nCols
;
uint8_t
idx
[];
}
STSKVRow
;
#pragma pack(pop)
#define TSROW_IS_KV_ROW(r) ((r)->flags & TSROW_KV_ROW)
// SValue
static
FORCE_INLINE
int32_t
tPutValue
(
uint8_t
*
p
,
SValue
*
pValue
,
int8_t
type
)
{
if
(
IS_VAR_DATA_TYPE
(
type
))
{
return
tPutBinary
(
p
,
pValue
->
pData
,
pValue
->
nData
);
}
else
{
if
(
p
)
memcpy
(
p
,
&
pValue
->
val
,
tDataTypes
[
type
].
bytes
);
return
tDataTypes
[
type
].
bytes
;
}
}
// SRow ========================================================================
// SRow ========================================================================
int32_t
tTSRowPut
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
)
{
#define ROW_FLG_KV ((uint8_t)0x10)
int32_t
code
=
0
;
ASSERT
(
taosArrayGetSize
(
aColVal
)
==
0
);
int32_t
tRowPut
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
)
{
int32_t
code
=
0
;
uint8_t
flag
=
0
;
uint8_t
flag
=
0
;
int32_t
iColVal
=
0
;
int32_t
iColVal
=
0
;
SColVal
*
pColVal
=
taosArrayGet
(
aColVal
,
iColVal
);
int32_t
nColVal
=
(
int32_t
)
taosArrayGetSize
(
aColVal
);
SColVal
*
pColVal
=
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
);
int32_t
iTColumn
=
0
;
int32_t
iTColumn
=
0
;
STColumn
*
pTColumn
=
pTSchema
->
columns
+
iTColumn
;
STColumn
*
pTColumn
=
pTSchema
->
columns
+
iTColumn
;
int32_t
ntp
=
sizeof
(
SRow
);
int32_t
nkv
=
sizeof
(
SRow
);
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
// VALUE
flag
|=
HAS_VALUE
;
}
else
if
(
COL_VAL_IS_NONE
(
pColVal
))
{
// NONE
flag
|=
HAS_NONE
;
}
else
{
// NULL
flag
|=
HAS_NULL
;
}
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
else
if
(
pColVal
->
cid
>
pTColumn
->
colId
)
{
// NONE
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
SRow
*
pRow
=
NULL
;
// todo
iColVal
=
0
;
pColVal
=
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
);
iTColumn
=
0
;
pTColumn
=
pTSchema
->
columns
+
iTColumn
;
if
(
ntp
<=
nkv
)
{
// tuple row
pRow
->
flag
=
flag
;
pRow
->
sver
=
pTSchema
->
version
;
pRow
->
len
=
ntp
;
while
(
pTColumn
)
{
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
...
@@ -88,18 +107,48 @@ int32_t tTSRowPut(SArray *aColVal, STSchema *pTSchema, SBuffer *pBuffer) {
...
@@ -88,18 +107,48 @@ int32_t tTSRowPut(SArray *aColVal, STSchema *pTSchema, SBuffer *pBuffer) {
flag
|=
HAS_NULL
;
flag
|=
HAS_NULL
;
}
}
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pColVal
=
(
++
iColVal
<
taosArrayGetSize
(
aColVal
))
?
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
else
if
(
pColVal
->
cid
<
pTColumn
->
colId
)
{
}
else
if
(
pColVal
->
cid
>
pTColumn
->
colId
)
{
// NONE
pColVal
=
(
++
iColVal
<
taosArrayGetSize
(
aColVal
))
?
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
}
else
{
// NONE
flag
|=
HAS_NONE
;
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
}
}
else
{
// kv row
pRow
->
flag
=
flag
|
ROW_FLG_KV
;
pRow
->
sver
=
pTSchema
->
version
;
pRow
->
len
=
ntp
;
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
// VALUE
flag
|=
HAS_VALUE
;
}
else
if
(
COL_VAL_IS_NONE
(
pColVal
))
{
// NONE
flag
|=
HAS_NONE
;
}
else
{
// NULL
flag
|=
HAS_NULL
;
}
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
else
if
(
pColVal
->
cid
>
pTColumn
->
colId
)
{
// NONE
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
}
else
{
// NONE
flag
|=
HAS_NONE
;
flag
|=
HAS_NONE
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
}
}
}
#if 0
#if 0
STColumn *pTColumn;
STColumn *pTColumn;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录