Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
ba621647
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22017
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看板
未验证
提交
ba621647
编写于
11月 24, 2022
作者:
S
Shengliang Guan
提交者:
GitHub
11月 24, 2022
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #18396 from taosdata/enh/row_optimize2
enh: row optimize2
上级
de4ef96a
4e739b45
变更
13
显示空白变更内容
内联
并排
Showing
13 changed file
with
686 addition
and
617 deletion
+686
-617
include/common/tdataformat.h
include/common/tdataformat.h
+29
-76
include/common/trow.h
include/common/trow.h
+9
-1
source/client/src/clientRawBlockWrite.c
source/client/src/clientRawBlockWrite.c
+12
-5
source/common/src/tdatablock.c
source/common/src/tdatablock.c
+1
-0
source/common/src/tdataformat.c
source/common/src/tdataformat.c
+596
-498
source/common/src/trow.c
source/common/src/trow.c
+6
-7
source/common/src/ttypes.c
source/common/src/ttypes.c
+2
-2
source/dnode/vnode/src/inc/tsdb.h
source/dnode/vnode/src/inc/tsdb.h
+5
-5
source/dnode/vnode/src/tsdb/tsdbCommit.c
source/dnode/vnode/src/tsdb/tsdbCommit.c
+11
-8
source/dnode/vnode/src/tsdb/tsdbDiskData.c
source/dnode/vnode/src/tsdb/tsdbDiskData.c
+5
-5
source/dnode/vnode/src/tsdb/tsdbSnapshot.c
source/dnode/vnode/src/tsdb/tsdbSnapshot.c
+2
-2
source/dnode/vnode/src/tsdb/tsdbUtil.c
source/dnode/vnode/src/tsdb/tsdbUtil.c
+7
-7
source/libs/parser/src/parInsertUtil.c
source/libs/parser/src/parInsertUtil.c
+1
-1
未找到文件。
include/common/tdataformat.h
浏览文件 @
ba621647
...
...
@@ -33,8 +33,8 @@ typedef struct STColumn STColumn;
typedef
struct
STSchema
STSchema
;
typedef
struct
SValue
SValue
;
typedef
struct
SColVal
SColVal
;
typedef
struct
S
TSRow2
STSRow2
;
typedef
struct
S
TSRowBuilder
STSRowBuild
er
;
typedef
struct
S
Row
SRow
;
typedef
struct
S
RowIter
SRowIt
er
;
typedef
struct
STagVal
STagVal
;
typedef
struct
STag
STag
;
typedef
struct
SColData
SColData
;
...
...
@@ -68,13 +68,10 @@ struct SBuffer {
void
tBufferDestroy
(
SBuffer
*
pBuffer
);
int32_t
tBufferInit
(
SBuffer
*
pBuffer
,
int64_t
size
);
int32_t
tBufferPut
(
SBuffer
*
pBuffer
,
const
void
*
pData
,
int64_t
nData
);
int32_t
tBufferReserve
(
SBuffer
*
pBuffer
,
int64_t
nData
,
void
**
ppData
);
// STSchema ================================
int32_t
tTSchemaCreate
(
int32_t
sver
,
SSchema
*
pSchema
,
int32_t
nCols
,
STSchema
**
ppTSchema
);
void
tTSchemaDestroy
(
STSchema
*
pTSchema
);
// SValue ================================
static
FORCE_INLINE
int32_t
tGetValue
(
uint8_t
*
p
,
SValue
*
pValue
,
int8_t
type
);
void
tDestroyTSchema
(
STSchema
*
pTSchema
);
// SColVal ================================
#define CV_FLAG_VALUE ((int8_t)0x0)
...
...
@@ -89,26 +86,14 @@ static FORCE_INLINE int32_t tGetValue(uint8_t *p, SValue *pValue, int8_t type);
#define COL_VAL_IS_NULL(CV) ((CV)->flag == CV_FLAG_NULL)
#define COL_VAL_IS_VALUE(CV) ((CV)->flag == CV_FLAG_VALUE)
// STSRow2 ================================
#define TSROW_LEN(PROW, V) tGetI32v((uint8_t *)(PROW)->data, (V) ? &(V) : NULL)
#define TSROW_SVER(PROW, V) tGetI32v((PROW)->data + TSROW_LEN(PROW, NULL), (V) ? &(V) : NULL)
int32_t
tTSRowNew
(
STSRowBuilder
*
pBuilder
,
SArray
*
pArray
,
STSchema
*
pTSchema
,
STSRow2
**
ppRow
);
int32_t
tTSRowClone
(
const
STSRow2
*
pRow
,
STSRow2
**
ppRow
);
void
tTSRowFree
(
STSRow2
*
pRow
);
void
tTSRowGet
(
STSRow2
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
int32_t
tTSRowToArray
(
STSRow2
*
pRow
,
STSchema
*
pTSchema
,
SArray
**
ppArray
);
int32_t
tPutTSRow
(
uint8_t
*
p
,
STSRow2
*
pRow
);
int32_t
tGetTSRow
(
uint8_t
*
p
,
STSRow2
**
ppRow
);
// STSRowBuilder ================================
#define tsRowBuilderInit() ((STSRowBuilder){0})
#define tsRowBuilderClear(B) \
do { \
if ((B)->pBuf) { \
taosMemoryFree((B)->pBuf); \
} \
} while (0)
// SRow ================================
int32_t
tRowBuild
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
);
void
tRowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
// SRowIter ================================
int32_t
tRowIterOpen
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SRowIter
**
ppIter
);
void
tRowIterClose
(
SRowIter
**
ppIter
);
SColVal
*
tRowIterNext
(
SRowIter
*
pIter
);
// STag ================================
int32_t
tTagNew
(
SArray
*
pArray
,
int32_t
version
,
int8_t
isJson
,
STag
**
ppTag
);
...
...
@@ -147,30 +132,18 @@ struct STSchema {
int32_t
numOfCols
;
int32_t
version
;
int32_t
flen
;
int32_t
vlen
;
int32_t
tlen
;
STColumn
columns
[];
};
#define TSROW_HAS_NONE ((uint8_t)0x1)
#define TSROW_HAS_NULL ((uint8_t)0x2U)
#define TSROW_HAS_VAL ((uint8_t)0x4U)
#define TSROW_KV_SMALL ((uint8_t)0x10U)
#define TSROW_KV_MID ((uint8_t)0x20U)
#define TSROW_KV_BIG ((uint8_t)0x40U)
#pragma pack(push, 1)
struct
STSRow2
{
struct
SRow
{
uint8_t
flag
;
uint8_t
rsv
;
uint16_t
sver
;
uint32_t
len
;
TSKEY
ts
;
uint8_t
flags
;
uint8_t
data
[];
};
#pragma pack(pop)
struct
STSRowBuilder
{
// STSRow2 tsRow;
int32_t
szBuf
;
uint8_t
*
pBuf
;
};
struct
SValue
{
union
{
...
...
@@ -258,37 +231,17 @@ typedef struct {
int32_t
nCols
;
schema_ver_t
version
;
uint16_t
flen
;
int32_t
vlen
;
int32_t
tlen
;
STColumn
*
columns
;
}
STSchemaBuilder
;
// use 2 bits for bitmap(default: STSRow/sub block)
#define TD_VTYPE_BITS 2
#define TD_VTYPE_PARTS 4 // PARTITIONS: 1 byte / 2 bits
#define TD_VTYPE_OPTR 3 // OPERATOR: 4 - 1, utilize to get remainder
#define TD_BITMAP_BYTES(cnt) (((cnt) + TD_VTYPE_OPTR) >> 2)
// use 1 bit for bitmap(super block)
#define TD_VTYPE_BITS_I 1
#define TD_VTYPE_PARTS_I 8 // PARTITIONS: 1 byte / 1 bit
#define TD_VTYPE_OPTR_I 7 // OPERATOR: 8 - 1, utilize to get remainder
#define TD_BITMAP_BYTES_I(cnt) (((cnt) + TD_VTYPE_OPTR_I) >> 3)
int32_t
tdInitTSchemaBuilder
(
STSchemaBuilder
*
pBuilder
,
schema_ver_t
version
);
void
tdDestroyTSchemaBuilder
(
STSchemaBuilder
*
pBuilder
);
void
tdResetTSchemaBuilder
(
STSchemaBuilder
*
pBuilder
,
schema_ver_t
version
);
int32_t
tdAddColToSchema
(
STSchemaBuilder
*
pBuilder
,
int8_t
type
,
int8_t
flags
,
col_id_t
colId
,
col_bytes_t
bytes
);
STSchema
*
tdGetSchemaFromBuilder
(
STSchemaBuilder
*
pBuilder
);
static
FORCE_INLINE
int32_t
tGetValue
(
uint8_t
*
p
,
SValue
*
pValue
,
int8_t
type
)
{
if
(
IS_VAR_DATA_TYPE
(
type
))
{
return
tGetBinary
(
p
,
&
pValue
->
pData
,
pValue
?
&
pValue
->
nData
:
NULL
);
}
else
{
memcpy
(
&
pValue
->
val
,
p
,
tDataTypes
[
type
].
bytes
);
return
tDataTypes
[
type
].
bytes
;
}
}
STSchema
*
tBuildTSchema
(
SSchema
*
aSchema
,
int32_t
numOfCols
,
int32_t
version
);
#endif
...
...
include/common/trow.h
浏览文件 @
ba621647
...
...
@@ -55,6 +55,14 @@ typedef struct STSRow {
#define TD_ROW_TP 0x0U // default
#define TD_ROW_KV 0x01U
#define TD_VTYPE_PARTS 4 // PARTITIONS: 1 byte / 2 bits
#define TD_VTYPE_OPTR 3 // OPERATOR: 4 - 1, utilize to get remainder
#define TD_BITMAP_BYTES(cnt) (((cnt) + TD_VTYPE_OPTR) >> 2)
#define TD_VTYPE_PARTS_I 8 // PARTITIONS: 1 byte / 1 bit
#define TD_VTYPE_OPTR_I 7 // OPERATOR: 8 - 1, utilize to get remainder
#define TD_BITMAP_BYTES_I(cnt) (((cnt) + TD_VTYPE_OPTR_I) >> 3)
/**
* @brief value type
* - for data from client input and STSRow in memory, 3 types of value none/null/norm available
...
...
@@ -244,7 +252,7 @@ int32_t tdGetBitmapValTypeI(const void *pBitmap, int16_t colIdx, TDRowValT *pVal
*/
static
FORCE_INLINE
void
*
tdGetBitmapAddrTp
(
STSRow
*
pRow
,
uint32_t
flen
)
{
// The primary TS key is stored separatedly.
return
POINTER_SHIFT
(
TD_ROW_DATA
(
pRow
),
flen
-
sizeof
(
TSKEY
)
);
return
POINTER_SHIFT
(
TD_ROW_DATA
(
pRow
),
flen
);
// return POINTER_SHIFT(pRow->ts, flen);
}
...
...
source/client/src/clientRawBlockWrite.c
浏览文件 @
ba621647
...
...
@@ -1275,6 +1275,7 @@ int taos_write_raw_block(TAOS* taos, int rows, char* pData, const char* tbname)
nVar
++
;
}
}
fLen
-=
sizeof
(
TSKEY
);
int32_t
extendedRowSize
=
rowSize
+
TD_ROW_HEAD_LEN
-
sizeof
(
TSKEY
)
+
nVar
*
sizeof
(
VarDataOffsetT
)
+
(
int32_t
)
TD_BITMAP_BYTES
(
numOfCols
-
1
);
...
...
@@ -1333,8 +1334,10 @@ int taos_write_raw_block(TAOS* taos, int rows, char* pData, const char* tbname)
}
}
if
(
pColumn
->
colId
!=
PRIMARYKEY_TIMESTAMP_COL_ID
)
{
offset
+=
TYPE_BYTES
[
pColumn
->
type
];
}
}
tdSRowEnd
(
&
rb
);
int32_t
rowLen
=
TD_ROW_LEN
(
rowData
);
rowData
=
POINTER_SHIFT
(
rowData
,
rowLen
);
...
...
@@ -1503,6 +1506,7 @@ static int32_t tmqWriteRawDataImpl(TAOS* taos, void* data, int32_t dataLen) {
nVar
++
;
}
}
fLen
-=
sizeof
(
TSKEY
);
int32_t
rows
=
rspObj
.
resInfo
.
numOfRows
;
int32_t
extendedRowSize
=
rowSize
+
TD_ROW_HEAD_LEN
-
sizeof
(
TSKEY
)
+
nVar
*
sizeof
(
VarDataOffsetT
)
+
...
...
@@ -1585,9 +1589,10 @@ static int32_t tmqWriteRawDataImpl(TAOS* taos, void* data, int32_t dataLen) {
tdAppendColValToRow
(
&
rb
,
pColumn
->
colId
,
pColumn
->
type
,
TD_VTYPE_NORM
,
colData
,
true
,
offset
,
k
);
}
}
if
(
pColumn
->
colId
!=
PRIMARYKEY_TIMESTAMP_COL_ID
)
{
offset
+=
TYPE_BYTES
[
pColumn
->
type
];
}
}
tdSRowEnd
(
&
rb
);
int32_t
rowLen
=
TD_ROW_LEN
(
rowData
);
rowData
=
POINTER_SHIFT
(
rowData
,
rowLen
);
...
...
@@ -1803,6 +1808,7 @@ static int32_t tmqWriteRawMetaDataImpl(TAOS* taos, void* data, int32_t dataLen)
nVar
++
;
}
}
fLen
-=
sizeof
(
TSKEY
);
int32_t
rows
=
rspObj
.
resInfo
.
numOfRows
;
int32_t
extendedRowSize
=
rowSize
+
TD_ROW_HEAD_LEN
-
sizeof
(
TSKEY
)
+
nVar
*
sizeof
(
VarDataOffsetT
)
+
...
...
@@ -1888,9 +1894,10 @@ static int32_t tmqWriteRawMetaDataImpl(TAOS* taos, void* data, int32_t dataLen)
tdAppendColValToRow
(
&
rb
,
pColumn
->
colId
,
pColumn
->
type
,
TD_VTYPE_NORM
,
colData
,
true
,
offset
,
k
);
}
}
if
(
pColumn
->
colId
!=
PRIMARYKEY_TIMESTAMP_COL_ID
)
{
offset
+=
TYPE_BYTES
[
pColumn
->
type
];
}
}
tdSRowEnd
(
&
rb
);
int32_t
rowLen
=
TD_ROW_LEN
(
rowData
);
rowData
=
POINTER_SHIFT
(
rowData
,
rowLen
);
...
...
source/common/src/tdatablock.c
浏览文件 @
ba621647
...
...
@@ -2052,6 +2052,7 @@ int32_t buildSubmitReqFromDataBlock(SSubmitReq** pReq, const SSDataBlock* pDataB
isStartKey
=
true
;
tdAppendColValToRow
(
&
rb
,
PRIMARYKEY_TIMESTAMP_COL_ID
,
TSDB_DATA_TYPE_TIMESTAMP
,
TD_VTYPE_NORM
,
var
,
true
,
offset
,
k
);
continue
;
// offset should keep 0 for next column
}
else
if
(
colDataIsNull_s
(
pColInfoData
,
j
))
{
tdAppendColValToRow
(
&
rb
,
PRIMARYKEY_TIMESTAMP_COL_ID
+
k
,
TSDB_DATA_TYPE_TIMESTAMP
,
TD_VTYPE_NULL
,
NULL
,
...
...
source/common/src/tdataformat.c
浏览文件 @
ba621647
...
...
@@ -43,607 +43,673 @@ int32_t tBufferPut(SBuffer *pBuffer, const void *pData, int64_t nData) {
return
code
;
}
int32_t
tBufferReserve
(
SBuffer
*
pBuffer
,
int64_t
nData
,
void
**
ppData
)
{
int32_t
code
=
tRealloc
(
&
pBuffer
->
pBuf
,
pBuffer
->
nBuf
+
nData
);
if
(
code
)
return
code
;
*
ppData
=
pBuffer
->
pBuf
+
pBuffer
->
nBuf
;
pBuffer
->
nBuf
+=
nData
;
return
code
;
}
// ================================
static
int32_t
tGetTagVal
(
uint8_t
*
p
,
STagVal
*
pTagVal
,
int8_t
isJson
);
// SRow ========================================================================
#define KV_FLG_LIT ((uint8_t)0x10)
#define KV_FLG_MID ((uint8_t)0x20)
#define KV_FLG_BIG ((uint8_t)0x30)
#define ROW_BIT_NONE ((uint8_t)0x0)
#define ROW_BIT_NULL ((uint8_t)0x1)
#define ROW_BIT_VALUE ((uint8_t)0x2)
#pragma pack(push, 1)
typedef
struct
{
int16_t
nCol
s
;
uint8_t
idx
[];
}
S
TSKVRow
;
int16_t
nCol
;
char
idx
[];
// uint8_t * | uint16_t * | uint32_t *
}
S
KVIdx
;
#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
;
}
}
// STSRow2 ========================================================================
static
void
setBitMap
(
uint8_t
*
pb
,
uint8_t
v
,
int32_t
idx
,
uint8_t
flags
)
{
if
(
pb
)
{
switch
(
flags
&
0xf
)
{
case
TSROW_HAS_NULL
|
TSROW_HAS_NONE
:
case
TSROW_HAS_VAL
|
TSROW_HAS_NONE
:
if
(
v
)
{
SET_BIT1
(
pb
,
idx
,
(
uint8_t
)
1
);
}
else
{
SET_BIT1
(
pb
,
idx
,
(
uint8_t
)
0
);
}
break
;
case
TSROW_HAS_VAL
|
TSROW_HAS_NULL
:
v
=
v
-
1
;
SET_BIT1
(
pb
,
idx
,
v
);
break
;
case
TSROW_HAS_VAL
|
TSROW_HAS_NULL
|
TSROW_HAS_NONE
:
SET_BIT2
(
pb
,
idx
,
v
);
break
;
default:
ASSERT
(
0
);
}
}
}
#define SET_IDX(p, i, n, f) \
#define ROW_SET_BITMAP(PB, FLAG, IDX, VAL) \
do { \
if ((f)&TSROW_KV_SMALL) { \
((uint8_t *)(p))[i] = (n); \
} else if ((f)&TSROW_KV_MID) { \
((uint16_t *)(p))[i] = (n); \
} else { \
((uint32_t *)(p))[i] = (n); \
if (PB) { \
switch (FLAG) { \
case (HAS_NULL | HAS_NONE): \
SET_BIT1(PB, IDX, VAL); \
break; \
case (HAS_VALUE | HAS_NONE): \
SET_BIT1(PB, IDX, (VAL) ? (VAL)-1 : 0); \
break; \
case (HAS_VALUE | HAS_NULL): \
SET_BIT1(PB, IDX, (VAL)-1); \
break; \
case (HAS_VALUE | HAS_NULL | HAS_NONE): \
SET_BIT2(PB, IDX, VAL); \
break; \
default: \
ASSERT(0); \
break; \
} \
} \
} while (0)
#if 0
int32_t tTSRowNew(STSRowBuilder *pBuilder, SArray *pArray, STSchema *pTSchema, STSRow2 **ppRow) {
int32_t code = 0;
#if 0
STColumn *pTColumn;
SColVal *pColVal;
int32_t nColVal = taosArrayGetSize(pArray);
int32_t iColVal;
ASSERT(nColVal > 0);
// try
uint8_t flags = 0;
uint32_t ntv = 0;
uint32_t nkv = 0;
int16_t nTag = 0;
uint32_t maxIdx = 0;
iColVal = 0;
for (int32_t iColumn = 0; iColumn < pTSchema->numOfCols; iColumn++) {
pTColumn = &pTSchema->columns[iColumn];
if (iColVal < nColVal) {
pColVal = (SColVal *)taosArrayGet(pArray, iColVal);
} else {
pColVal = NULL;
}
if (iColumn == 0) {
ASSERT(pColVal->cid == pTColumn->colId);
ASSERT(pTColumn->type == TSDB_DATA_TYPE_TIMESTAMP);
ASSERT(pTColumn->colId == PRIMARYKEY_TIMESTAMP_COL_ID);
int32_t
tRowBuild
(
SArray
*
aColVal
,
STSchema
*
pTSchema
,
SBuffer
*
pBuffer
)
{
int32_t
code
=
0
;
iColVal++;
} else {
ASSERT
(
taosArrayGetSize
(
aColVal
)
>
0
);
ASSERT
(((
SColVal
*
)
aColVal
->
pData
)[
0
].
cid
==
PRIMARYKEY_TIMESTAMP_COL_ID
);
ASSERT
(((
SColVal
*
)
aColVal
->
pData
)[
0
].
type
==
TSDB_DATA_TYPE_TIMESTAMP
);
// scan ---------------
uint8_t
flag
=
0
;
int32_t
iColVal
=
1
;
const
int32_t
nColVal
=
taosArrayGetSize
(
aColVal
);
SColVal
*
pColVal
=
(
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
int32_t
iTColumn
=
1
;
STColumn
*
pTColumn
=
pTSchema
->
columns
+
iTColumn
;
int32_t
ntp
=
0
;
int32_t
nkv
=
0
;
int32_t
maxIdx
=
0
;
int32_t
nIdx
=
0
;
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
iColVal++;
if (COL_VAL_IS_NONE(pColVal)) {
flags |= TSROW_HAS_NONE;
} else if (COL_VAL_IS_NULL(pColVal)) {
flags |= TSROW_HAS_NULL;
ntp
+=
TYPE_BYTES
[
pTColumn
->
type
];
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
// VALUE
flag
|=
HAS_VALUE
;
maxIdx
=
nkv
;
nTag++;
nkv += tPutI16v(NULL, -pTColumn->colId);
} else {
flags |= TSROW_HAS_VAL;
maxIdx = nkv;
nTag++;
nkv += tPutI16v(NULL, pTColumn->colId);
nkv += tPutValue(NULL, &pColVal->value, pTColumn->type);
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
ntv += tPutValue(NULL, &pColVal->value, pTColumn->type);
}
ntp
=
ntp
+
tPutU32v
(
NULL
,
pColVal
->
value
.
nData
)
+
pColVal
->
value
.
nData
;
nkv
=
nkv
+
tPutI16v
(
NULL
,
pTColumn
->
colId
)
+
tPutU32v
(
NULL
,
pColVal
->
value
.
nData
)
+
pColVal
->
value
.
nData
;
}
else
{
nkv
=
nkv
+
tPutI16v
(
NULL
,
pTColumn
->
colId
)
+
pTColumn
->
bytes
;
}
} else if (pColVal->cid > pTColumn->colId) {
flags |= TSROW_HAS_NONE;
nIdx
++
;
}
else
if
(
COL_VAL_IS_NONE
(
pColVal
))
{
// NONE
flag
|=
HAS_NONE
;
}
else
if
(
COL_VAL_IS_NULL
(
pColVal
))
{
// NULL
flag
|=
HAS_NULL
;
maxIdx
=
nkv
;
nkv
+=
tPutI16v
(
NULL
,
-
pTColumn
->
colId
);
nIdx
++
;
}
else
{
ASSERT
(
0
);
}
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
;
ntp
+=
TYPE_BYTES
[
pTColumn
->
type
];
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
flags |= TSROW_HAS_NONE
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
flag
|=
HAS_NONE
;
ntp
+=
TYPE_BYTES
[
pTColumn
->
type
];
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
ASSERT(flags);
// decide
uint32_t nData = 0;
uint32_t nDataT = 0;
uint32_t nDataK = 0;
if (flags == TSROW_HAS_NONE || flags == TSROW_HAS_NULL) {
nData = 0;
} else {
switch (flags) {
case TSROW_HAS_VAL:
nDataT = pTSchema->flen + ntv;
// compare ---------------
switch
(
flag
)
{
case
HAS_NONE
:
case
HAS_NULL
:
ntp
=
sizeof
(
SRow
);
break
;
case TSROW_HAS_NULL | TSROW_HAS_NON
E:
nDataT = BIT1_SIZE(pTSchema->numOfCols - 1)
;
case
HAS_VALU
E
:
ntp
=
sizeof
(
SRow
)
+
ntp
;
break
;
case TSROW_HAS_VAL | TSROW_HAS_NONE:
case TSROW_HAS_VAL | TSROW_HAS_NULL:
nDataT = BIT1_SIZE(pTSchema->numOfCols - 1) + pTSchema->flen + ntv;
case
(
HAS_NULL
|
HAS_NONE
):
ntp
=
sizeof
(
SRow
)
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
);
break
;
case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
nDataT = BIT2_SIZE(pTSchema->numOfCols - 1) + pTSchema->flen + ntv;
case
(
HAS_VALUE
|
HAS_NONE
):
case
(
HAS_VALUE
|
HAS_NULL
):
ntp
=
sizeof
(
SRow
)
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
)
+
ntp
;
break
;
default:
case
(
HAS_VALUE
|
HAS_NULL
|
HAS_NONE
):
ntp
=
sizeof
(
SRow
)
+
BIT2_SIZE
(
pTSchema
->
numOfCols
-
1
)
+
ntp
;
break
;
default:
ASSERT
(
0
);
break
;
}
uint8_t tflags = 0;
if
(
maxIdx
<=
UINT8_MAX
)
{
nDataK = sizeof(STSKVRow) + sizeof(uint8_t) * nTag
+ nkv;
tflags |= TSROW_KV_SMALL
;
nkv
=
sizeof
(
SRow
)
+
sizeof
(
SKVIdx
)
+
nIdx
+
nkv
;
flag
|=
KV_FLG_LIT
;
}
else
if
(
maxIdx
<=
UINT16_MAX
)
{
nDataK = sizeof(STSKVRow) + sizeof(uint16_t) * nTag
+ nkv;
tflags |= TSROW_KV
_MID;
nkv
=
sizeof
(
SRow
)
+
sizeof
(
SKVIdx
)
+
(
nIdx
<<
1
)
+
nkv
;
flag
|=
KV_FLG
_MID
;
}
else
{
nDataK = sizeof(STSKVRow) + sizeof(uint32_t) * nTag
+ nkv;
tflags |= TSROW_KV
_BIG;
nkv
=
sizeof
(
SRow
)
+
sizeof
(
SKVIdx
)
+
(
nIdx
<<
2
)
+
nkv
;
flag
|=
KV_FLG
_BIG
;
}
if (nDataT <= nDataK
) {
nData = nDataT
;
int32_t
nRow
;
if
(
nkv
<
ntp
)
{
nRow
=
nkv
;
}
else
{
nData = nDataK;
flags |= tflags;
}
nRow
=
ntp
;
flag
&=
((
uint8_t
)
0x0f
);
}
// alloc
if (pBuilder) {
// create from a builder
if (nData == 0) {
pBuilder->tsRow.nData = 0;
pBuilder->tsRow.pData = NULL;
} else {
if (pBuilder->szBuf < nData) {
uint8_t *p = taosMemoryRealloc(pBuilder->pBuf, nData);
if (p == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
// alloc --------------
SRow
*
pRow
=
NULL
;
code
=
tBufferReserve
(
pBuffer
,
nRow
,
(
void
**
)
&
pRow
);
if
(
code
)
return
code
;
// build --------------
pColVal
=
(
SColVal
*
)
taosArrayGet
(
aColVal
,
0
);
pRow
->
flag
=
flag
;
pRow
->
rsv
=
0
;
pRow
->
sver
=
pTSchema
->
version
;
pRow
->
len
=
nRow
;
memcpy
(
&
pRow
->
ts
,
&
pColVal
->
value
.
val
,
sizeof
(
TSKEY
));
if
(
flag
==
HAS_NONE
||
flag
==
HAS_NULL
)
{
goto
_exit
;
}
pBuilder->pBuf = p;
pBuilder->szBuf = nData;
}
pBuilder->tsRow.nData = nData;
pBuilder->tsRow.pData = pBuilder->pBuf;
iColVal
=
1
;
pColVal
=
(
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
iTColumn
=
1
;
pTColumn
=
pTSchema
->
columns
+
iTColumn
;
if
(
flag
&
0xf0
)
{
// KV
SKVIdx
*
pIdx
=
(
SKVIdx
*
)
pRow
->
data
;
int32_t
iIdx
=
0
;
int32_t
nv
=
0
;
uint8_t
*
pv
=
NULL
;
if
(
flag
&
KV_FLG_LIT
)
{
pv
=
pIdx
->
idx
+
nIdx
;
}
else
if
(
flag
&
KV_FLG_MID
)
{
pv
=
pIdx
->
idx
+
(
nIdx
<<
1
);
}
else
{
pv
=
pIdx
->
idx
+
(
nIdx
<<
2
);
}
pIdx
->
nCol
=
nIdx
;
*ppRow = &pBuilder->tsRow;
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
if
(
flag
&
KV_FLG_LIT
)
{
((
uint8_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint8_t
)
nv
;
}
else
if
(
flag
&
KV_FLG_MID
)
{
((
uint16_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint16_t
)
nv
;
}
else
{
// create a new one
*ppRow = (STSRow2 *)taosMemoryMalloc(sizeof(STSRow2));
if (*ppRow == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
goto _exit;
((
uint32_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint32_t
)
nv
;
}
if (nData == 0) {
(*ppRow)->nData = 0;
(*ppRow)->pData = NULL;
iIdx
++
;
nv
+=
tPutI16v
(
pv
+
nv
,
pTColumn
->
colId
);
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
nv
+=
tPutU32v
(
pv
+
nv
,
pColVal
->
value
.
nData
);
memcpy
(
pv
+
nv
,
pColVal
->
value
.
pData
,
pColVal
->
value
.
nData
);
nv
+=
pColVal
->
value
.
nData
;
}
else
{
(*ppRow)->nData = nData;
(*ppRow)->pData = taosMemoryMalloc(nData);
if ((*ppRow)->pData == NULL) {
taosMemoryFree(*ppRow);
code = TSDB_CODE_OUT_OF_MEMORY;
goto _exit;
memcpy
(
pv
+
nv
,
&
pColVal
->
value
.
val
,
pTColumn
->
bytes
);
nv
+=
pTColumn
->
bytes
;
}
}
else
if
(
COL_VAL_IS_NULL
(
pColVal
))
{
if
(
flag
&
KV_FLG_LIT
)
{
((
uint8_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint8_t
)
nv
;
}
else
if
(
flag
&
KV_FLG_MID
)
{
((
uint16_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint16_t
)
nv
;
}
else
{
((
uint32_t
*
)
pIdx
->
idx
)[
iIdx
]
=
(
uint32_t
)
nv
;
}
iIdx
++
;
nv
+=
tPutI16v
(
pv
+
nv
,
-
pTColumn
->
colId
);
}
// build
(*ppRow)->flags = flags;
(*ppRow)->sver = pTSchema->version;
pColVal = (SColVal *)taosArrayGet(pArray, 0);
(*ppRow)->ts = pColVal->value.ts;
if ((*ppRow)->pData) {
STSKVRow *pTSKVRow = NULL;
uint8_t *pidx = NULL;
uint8_t *pkv = NULL;
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
else
if
(
pColVal
->
cid
>
pTColumn
->
colId
)
{
// NONE
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
}
else
{
// NONE
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
}
}
else
{
// TUPLE
uint8_t
*
pb
=
NULL
;
uint8_t
*
pf
=
NULL
;
uint8_t *ptv = NULL;
nkv = 0;
ntv = 0;
iColVal = 1;
uint8_t
*
pv
=
NULL
;
int32_t
nv
=
0
;
if ((flags & 0xf0) == 0) {
switch (flags & 0xf) {
case TSROW_HAS_VAL:
pf = (*ppRow)->pData;
ptv = pf + pTSchema->flen;
switch
(
flag
)
{
case
(
HAS_NULL
|
HAS_NONE
):
pb
=
pRow
->
data
;
break
;
case TSROW_HAS_NULL | TSROW_HAS_NONE:
pb = (*ppRow)->pData;
case
HAS_VALUE
:
pf
=
pRow
->
data
;
pv
=
pf
+
pTSchema
->
flen
;
break
;
case TSROW_HAS_VAL | TSROW_HAS_NONE
:
case TSROW_HAS_VAL | TSROW_HAS_NULL
:
pb = (*ppRow)->pD
ata;
case
(
HAS_VALUE
|
HAS_NONE
)
:
case
(
HAS_VALUE
|
HAS_NULL
)
:
pb
=
pRow
->
d
ata
;
pf
=
pb
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
);
pt
v = pf + pTSchema->flen;
p
v
=
pf
+
pTSchema
->
flen
;
break
;
case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE
:
pb = (*ppRow)->pD
ata;
case
(
HAS_VALUE
|
HAS_NULL
|
HAS_NONE
)
:
pb
=
pRow
->
d
ata
;
pf
=
pb
+
BIT2_SIZE
(
pTSchema
->
numOfCols
-
1
);
pt
v = pf + pTSchema->flen;
p
v
=
pf
+
pTSchema
->
flen
;
break
;
default:
ASSERT
(
0
);
break
;
}
} else {
pTSKVRow = (STSKVRow *)(*ppRow)->pData;
pTSKVRow->nCols = 0;
pidx = pTSKVRow->idx;
if (flags & TSROW_KV_SMALL) {
pkv = pidx + sizeof(uint8_t) * nTag;
} else if (flags & TSROW_KV_MID) {
pkv = pidx + sizeof(uint16_t) * nTag;
} else {
pkv = pidx + sizeof(uint32_t) * nTag;
}
}
for (int32_t iColumn = 1; iColumn < pTSchema->numOfCols; iColumn++) {
pTColumn = &pTSchema->columns[iColumn];
if (iColVal < nColVal) {
pColVal = (SColVal *)taosArrayGet(pArray, iColVal);
} else {
pColVal = NULL;
}
// build impl
while
(
pTColumn
)
{
if
(
pColVal
)
{
if
(
pColVal
->
cid
==
pTColumn
->
colId
)
{
iColVal++;
if (COL_VAL_IS_NONE(pColVal)) {
goto _set_none;
} else if (COL_VAL_IS_NULL(pColVal)) {
goto _set_null;
} else {
goto _set_value;
}
} else if (pColVal->cid > pTColumn->colId) {
goto _set_none;
} else {
ASSERT(0);
}
} else {
goto _set_none;
}
if
(
COL_VAL_IS_VALUE
(
pColVal
))
{
// VALUE
ROW_SET_BITMAP
(
pb
,
flag
,
iTColumn
-
1
,
ROW_BIT_VALUE
);
_set_none:
if ((flags & 0xf0) == 0) {
setBitMap(pb, 0, iColumn - 1, flags);
if (flags & TSROW_HAS_VAL) { // set 0
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
*(VarDataOffsetT *)(pf + pTColumn->offset) = 0
;
} else {
tPutValue(pf + pTColumn->offset, &((SValue){0}), 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
;
}
continue;
_set_null:
if ((flags & 0xf0) == 0) {
setBitMap(pb, 1, iColumn - 1, flags);
if (flags & TSROW_HAS_VAL) { // set 0
if (IS_VAR_DATA_TYPE(pTColumn->type)) {
*(VarDataOffsetT *)(pf + pTColumn->offset) = 0;
}
else
{
tPutValue(pf + pTColumn->offset, &((SValue){0}), pTColumn->type
);
memcpy
(
pf
+
pTColumn
->
offset
,
&
pColVal
->
value
.
val
,
TYPE_BYTES
[
pTColumn
->
type
]
);
}
}
else
if
(
COL_VAL_IS_NONE
(
pColVal
))
{
// NONE
ROW_SET_BITMAP
(
pb
,
flag
,
iTColumn
-
1
,
ROW_BIT_NONE
);
if
(
pf
)
memset
(
pf
+
pTColumn
->
offset
,
0
,
TYPE_BYTES
[
pTColumn
->
type
]);
}
else
{
// NULL
ROW_SET_BITMAP
(
pb
,
flag
,
iTColumn
-
1
,
ROW_BIT_NULL
);
if
(
pf
)
memset
(
pf
+
pTColumn
->
offset
,
0
,
TYPE_BYTES
[
pTColumn
->
type
]);
}
} else {
SET_IDX(pidx, pTSKVRow->nCols, nkv, flags);
pTSKVRow->nCols++;
nkv += tPutI16v(pkv + nkv, -pTColumn->colId);
}
continue;
_set_value:
if ((flags & 0xf0) == 0) {
setBitMap(pb, 2, iColumn - 1, flags);
if (IS_VAR_DATA_TYPE(pTColumn->type)) {
*(VarDataOffsetT *)(pf + pTColumn->offset) = ntv;
ntv += tPutValue(ptv + ntv, &pColVal->value, pTColumn->type);
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
else
if
(
pColVal
->
cid
>
pTColumn
->
colId
)
{
// NONE
ROW_SET_BITMAP
(
pb
,
flag
,
iTColumn
-
1
,
ROW_BIT_NONE
);
if
(
pf
)
memset
(
pf
+
pTColumn
->
offset
,
0
,
TYPE_BYTES
[
pTColumn
->
type
]);
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
else
{
tPutValue(pf + pTColumn->offset, &pColVal->value, pTColumn->type)
;
pColVal
=
(
++
iColVal
<
nColVal
)
?
(
SColVal
*
)
taosArrayGet
(
aColVal
,
iColVal
)
:
NULL
;
}
} else {
SET_IDX(pidx, pTSKVRow->nCols, nkv, flags);
pTSKVRow->nCols++;
nkv += tPutI16v(pkv + nkv, pColVal->cid);
nkv += tPutValue(pkv + nkv, &pColVal->value, pTColumn->type);
}
else
{
// NONE
ROW_SET_BITMAP
(
pb
,
flag
,
iTColumn
-
1
,
ROW_BIT_NONE
);
if
(
pf
)
memset
(
pf
+
pTColumn
->
offset
,
0
,
TYPE_BYTES
[
pTColumn
->
type
]);
pTColumn
=
(
++
iTColumn
<
pTSchema
->
numOfCols
)
?
pTSchema
->
columns
+
iTColumn
:
NULL
;
}
continue;
}
}
#endif
_exit:
return
code
;
}
int32_t tTSRowClone(const STSRow2 *pRow, STSRow2 **ppRow) {
int32_t code = 0;
int32_t rLen = 0;
TSROW_LEN(pRow, rLen);
(*ppRow) = (STSRow2 *)taosMemoryMalloc(rLen);
if (*ppRow == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
goto _exit;
}
memcpy(*ppRow, pRow, rLen);
_exit:
return code;
}
void tTSRowFree(STSRow2 *pRow) {
if (pRow) {
taosMemoryFree(pRow);
}
}
void tTSRowGet(STSRow2 *pRow, STSchema *pTSchema, int32_t iCol, SColVal *pColVal) {
uint8_t isTuple = ((pRow->flags & 0xf0) == 0) ? 1 : 0;
STColumn *pTColumn = &pTSchema->columns[iCol];
uint8_t flags = pRow->flags & (uint8_t)0xf;
SValue value;
void
tRowGet
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
)
{
ASSERT
(
iCol
<
pTSchema
->
numOfCols
);
ASSERT(flags);
ASSERT
(
pRow
->
sver
==
pTSchema
->
version
);
STColumn
*
pTColumn
=
pTSchema
->
columns
+
iCol
;
if
(
iCol
==
0
)
{
value.ts = pRow->ts;
goto _return_value;
pColVal
->
cid
=
pTColumn
->
colId
;
pColVal
->
type
=
pTColumn
->
type
;
pColVal
->
flag
=
CV_FLAG_VALUE
;
memcpy
(
&
pColVal
->
value
.
val
,
&
pRow
->
ts
,
sizeof
(
TSKEY
));
return
;
}
if (flags == TSROW_HAS_NONE) {
goto _return_none;
} else if (flags == TSROW_HAS_NULL) {
goto _return_null;
if
(
pRow
->
flag
==
HAS_NONE
)
{
*
pColVal
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
}
ASSERT(pRow->nData && pRow->pData);
if
(
pRow
->
flag
==
HAS_NULL
)
{
*
pColVal
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
}
if (isTuple) {
uint8_t *pb = pRow->pData;
uint8_t *pf = NULL;
if
(
pRow
->
flag
&
0xf0
)
{
// KV Row
SKVIdx
*
pIdx
=
(
SKVIdx
*
)
pRow
->
data
;
uint8_t
*
pv
=
NULL
;
uint8_t *p;
uint8_t b;
// bit
switch (flags) {
case TSROW_HAS_VAL:
pf = pb;
break;
case TSROW_HAS_NULL | TSROW_HAS_NONE:
b = GET_BIT1(pb, iCol - 1);
if (b == 0) {
goto _return_none;
} else {
goto _return_null;
}
case TSROW_HAS_VAL | TSROW_HAS_NONE:
b = GET_BIT1(pb, iCol - 1);
if (b == 0) {
goto _return_none;
} else {
pf = pb + BIT1_SIZE(pTSchema->numOfCols - 1);
break;
}
case TSROW_HAS_VAL | TSROW_HAS_NULL:
b = GET_BIT1(pb, iCol - 1);
if (b == 0) {
goto _return_null;
if
(
pRow
->
flag
&
KV_FLG_LIT
)
{
pv
=
pIdx
->
idx
+
pIdx
->
nCol
;
}
else
if
(
pRow
->
flag
&
KV_FLG_MID
)
{
pv
=
pIdx
->
idx
+
(
pIdx
->
nCol
<<
1
);
}
else
{
pf = pb + BIT1_SIZE(pTSchema->numOfCols - 1);
break;
}
case TSROW_HAS_VAL | TSROW_HAS_NULL | TSROW_HAS_NONE:
b = GET_BIT2(pb, iCol - 1);
if (b == 0) {
goto _return_none;
} else if (b == 1) {
goto _return_null;
} else {
pf = pb + BIT2_SIZE(pTSchema->numOfCols - 1);
break;
pv
=
pIdx
->
idx
+
(
pIdx
->
nCol
<<
2
);
}
default:
ASSERT(0);
}
ASSERT(pf);
p = pf + pTColumn->offset;
if (IS_VAR_DATA_TYPE(pTColumn->type)) {
pv = pf + pTSchema->flen;
p = pv + *(VarDataOffsetT *)p;
}
tGetValue(p, &value, pTColumn->type);
goto _return_value;
} else {
STSKVRow *pRowK = (STSKVRow *)pRow->pData;
int16_t
lidx
=
0
;
int16_t ridx = pRowK->nCols - 1;
uint8_t *p;
int16_t midx;
uint32_t n;
int16_t cid;
ASSERT(pRowK->nCols > 0);
if (pRow->flags & TSROW_KV_SMALL) {
p = pRow->pData + sizeof(STSKVRow) + sizeof(uint8_t) * pRowK->nCols;
} else if (pRow->flags & TSROW_KV_MID) {
p = pRow->pData + sizeof(STSKVRow) + sizeof(uint16_t) * pRowK->nCols;
} else if (pRow->flags & TSROW_KV_BIG) {
p = pRow->pData + sizeof(STSKVRow) + sizeof(uint32_t) * pRowK->nCols;
} else {
ASSERT(0);
}
int16_t
ridx
=
pIdx
->
nCol
-
1
;
while
(
lidx
<=
ridx
)
{
midx = (lidx + ridx) / 2
;
if (pRow->flag
s & TSROW_KV_SMALL
) {
n = ((uint8_t *)pRowK->idx)[midx
];
} else if (pRow->flag
s & TSROW_KV
_MID) {
n = ((uint16_t *)pRowK->idx)[midx
];
int16_t
mid
=
(
lidx
+
ridx
)
>>
1
;
uint8_t
*
pData
=
NULL
;
if
(
pRow
->
flag
&
KV_FLG_LIT
)
{
pData
=
pv
+
((
uint8_t
*
)
pIdx
->
idx
)[
mid
];
}
else
if
(
pRow
->
flag
&
KV_FLG
_MID
)
{
pData
=
pv
+
((
uint16_t
*
)
pIdx
->
idx
)[
mid
];
}
else
{
n = ((uint32_t *)pRowK->idx)[midx
];
pData
=
pv
+
((
uint32_t
*
)
pIdx
->
idx
)[
mid
];
}
n += tGetI16v(p + n, &cid);
int16_t
cid
;
pData
+=
tGetI16v
(
pData
,
&
cid
);
if
(
TABS
(
cid
)
==
pTColumn
->
colId
)
{
if
(
cid
<
0
)
{
goto _return_null
;
*
pColVal
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
)
;
}
else
{
n += tGetValue(p + n, &value, pTColumn->type)
;
goto _return_valu
e;
}
pColVal
->
cid
=
pTColumn
->
colId
;
pColVal
->
type
=
pTColumn
->
typ
e
;
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) {
ridx = midx -
1;
}
else
if
(
TABS
(
cid
)
<
pTColumn
->
colId
)
{
lidx
=
mid
+
1
;
}
else
{
lidx = midx +
1;
ridx
=
mid
-
1
;
}
}
// not found, return NONE
goto _return_none;
*
pColVal
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
}
else
{
// Tuple Row
uint8_t
*
pf
=
NULL
;
uint8_t
*
pv
=
NULL
;
uint8_t
bv
=
ROW_BIT_VALUE
;
switch
(
pRow
->
flag
)
{
case
HAS_VALUE
:
pf
=
pRow
->
data
;
pv
=
pf
+
pTSchema
->
flen
;
break
;
case
(
HAS_NULL
|
HAS_NONE
):
bv
=
GET_BIT1
(
pRow
->
data
,
iCol
-
1
);
break
;
case
(
HAS_VALUE
|
HAS_NONE
):
bv
=
GET_BIT1
(
pRow
->
data
,
iCol
-
1
);
if
(
bv
)
bv
++
;
pf
=
pRow
->
data
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
);
pv
=
pf
+
pTSchema
->
flen
;
break
;
case
(
HAS_VALUE
|
HAS_NULL
):
bv
=
GET_BIT1
(
pRow
->
data
,
iCol
-
1
);
bv
++
;
pf
=
pRow
->
data
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
);
pv
=
pf
+
pTSchema
->
flen
;
break
;
case
(
HAS_VALUE
|
HAS_NULL
|
HAS_NONE
):
bv
=
GET_BIT2
(
pRow
->
data
,
iCol
-
1
);
pf
=
pRow
->
data
+
BIT2_SIZE
(
pTSchema
->
numOfCols
-
1
);
pv
=
pf
+
pTSchema
->
flen
;
break
;
default:
break
;
}
_return_none:
if
(
bv
==
ROW_BIT_NONE
)
{
*
pColVal
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
_return_null:
}
else
if
(
bv
==
ROW_BIT_NULL
)
{
*
pColVal
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
return
;
}
_return_value:
*pColVal = COL_VAL_VALUE(pTColumn->colId, pTColumn->type, value);
return;
pColVal
->
cid
=
pTColumn
->
colId
;
pColVal
->
type
=
pTColumn
->
type
;
pColVal
->
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
uint8_t
*
pData
=
pv
+
*
(
int32_t
*
)(
pf
+
pTColumn
->
offset
);
pData
+=
tGetU32v
(
pData
,
&
pColVal
->
value
.
nData
);
if
(
pColVal
->
value
.
nData
)
{
pColVal
->
value
.
pData
=
pData
;
}
else
{
pColVal
->
value
.
pData
=
NULL
;
}
}
else
{
memcpy
(
&
pColVal
->
value
.
val
,
pv
+
pTColumn
->
offset
,
pTColumn
->
bytes
);
}
}
}
int32_t tTSRowToArray(STSRow2 *pRow, STSchema *pTSchema, SArray **ppArray) {
int32_t code = 0;
// SRowIter ========================================
struct
SRowIter
{
SRow
*
pRow
;
STSchema
*
pTSchema
;
int32_t
iTColumn
;
union
{
struct
{
// kv
int32_t
iCol
;
SKVIdx
*
pIdx
;
};
struct
{
// tuple
uint8_t
*
pb
;
uint8_t
*
pf
;
};
uint8_t
*
pv
;
};
SColVal
cv
;
};
(*ppArray) = taosArrayInit(pTSchema->numOfCols, sizeof(SColVal));
if (*ppArray == NULL) {
code = TSDB_CODE_OUT_OF_MEMORY;
int32_t
tRowIterOpen
(
SRow
*
pRow
,
STSchema
*
pTSchema
,
SRowIter
**
ppIter
)
{
ASSERT
(
pRow
->
sver
==
pTSchema
->
version
);
int32_t
code
=
0
;
SRowIter
*
pIter
=
taosMemoryCalloc
(
1
,
sizeof
(
*
pIter
));
if
(
pIter
==
NULL
)
{
code
=
TSDB_CODE_TDB_OUT_OF_MEMORY
;
goto
_exit
;
}
for (int32_t iColumn = 0; iColumn < pTSchema->numOfCols; iColumn++) {
tTSRowGet(pRow, pTSchema, iColumn, &cv);
taosArrayPush(*ppArray, &cv);
}
pIter
->
pRow
=
pRow
;
pIter
->
pTSchema
=
pTSchema
;
pIter
->
iTColumn
=
0
;
if
(
pRow
->
flag
==
HAS_NONE
||
pRow
->
flag
==
HAS_NULL
)
goto
_exit
;
if
(
pRow
->
flag
&
0xf0
)
{
pIter
->
iCol
=
0
;
pIter
->
pIdx
=
(
SKVIdx
*
)
pRow
->
data
;
if
(
pRow
->
flag
&
KV_FLG_LIT
)
{
pIter
->
pv
=
pIter
->
pIdx
->
idx
+
pIter
->
pIdx
->
nCol
;
}
else
if
(
pRow
->
flag
&
KV_FLG_MID
)
{
pIter
->
pv
=
pIter
->
pIdx
->
idx
+
(
pIter
->
pIdx
->
nCol
<<
1
);
}
else
{
pIter
->
pv
=
pIter
->
pIdx
->
idx
+
(
pIter
->
pIdx
->
nCol
<<
2
);
}
}
else
{
switch
(
pRow
->
flag
)
{
case
(
HAS_NULL
|
HAS_NONE
):
pIter
->
pb
=
pRow
->
data
;
break
;
case
HAS_VALUE
:
pIter
->
pf
=
pRow
->
data
;
pIter
->
pv
=
pIter
->
pf
+
pTSchema
->
flen
;
break
;
case
(
HAS_VALUE
|
HAS_NONE
):
case
(
HAS_VALUE
|
HAS_NULL
):
pIter
->
pb
=
pRow
->
data
;
pIter
->
pf
=
pRow
->
data
+
BIT1_SIZE
(
pTSchema
->
numOfCols
-
1
);
pIter
->
pv
=
pIter
->
pf
+
pTSchema
->
flen
;
break
;
case
(
HAS_VALUE
|
HAS_NULL
|
HAS_NONE
):
pIter
->
pb
=
pRow
->
data
;
pIter
->
pf
=
pRow
->
data
+
BIT2_SIZE
(
pTSchema
->
numOfCols
-
1
);
pIter
->
pv
=
pIter
->
pf
+
pTSchema
->
flen
;
break
;
default:
ASSERT
(
0
);
break
;
}
}
_exit:
if
(
code
)
{
*
ppIter
=
NULL
;
if
(
pIter
)
taosMemoryFree
(
pIter
);
}
else
{
*
ppIter
=
pIter
;
}
return
code
;
}
#endif
int32_t
tPutTSRow
(
uint8_t
*
p
,
STSRow2
*
pRow
)
{
int32_t
n
=
0
;
TSROW_LEN
(
pRow
,
n
);
if
(
p
)
{
memcpy
(
p
,
pRow
,
n
);
void
tRowIterClose
(
SRowIter
**
ppIter
)
{
SRowIter
*
pIter
=
*
ppIter
;
if
(
pIter
)
{
taosMemoryFree
(
pIter
);
}
return
n
;
*
ppIter
=
NULL
;
}
int32_t
tGetTSRow
(
uint8_t
*
p
,
STSRow2
**
ppRow
)
{
int32_t
n
=
0
;
SColVal
*
tRowIterNext
(
SRowIter
*
pIter
)
{
if
(
pIter
->
iTColumn
>=
pIter
->
pTSchema
->
numOfCols
)
{
return
NULL
;
}
*
ppRow
=
(
STSRow2
*
)
p
;
TSROW_LEN
(
*
ppRow
,
n
);
STColumn
*
pTColumn
=
pIter
->
pTSchema
->
columns
+
pIter
->
iTColumn
;
return
n
;
}
// timestamp
if
(
0
==
pIter
->
iTColumn
)
{
pIter
->
cv
.
cid
=
pTColumn
->
colId
;
pIter
->
cv
.
type
=
pTColumn
->
type
;
pIter
->
cv
.
flag
=
CV_FLAG_VALUE
;
memcpy
(
&
pIter
->
cv
.
value
.
val
,
&
pIter
->
pRow
->
ts
,
sizeof
(
TSKEY
));
goto
_exit
;
}
// STSchema ========================================
int32_t
tTSchemaCreate
(
int32_t
sver
,
SSchema
*
pSchema
,
int32_t
ncols
,
STSchema
**
ppTSchema
)
{
*
ppTSchema
=
(
STSchema
*
)
taosMemoryMalloc
(
sizeof
(
STSchema
)
+
sizeof
(
STColumn
)
*
ncols
);
if
(
*
ppTSchema
==
NULL
)
{
terrno
=
TSDB_CODE_OUT_OF_MEMORY
;
return
-
1
;
if
(
pIter
->
pRow
->
flag
==
HAS_NONE
)
{
pIter
->
cv
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
goto
_exit
;
}
if
(
pIter
->
pRow
->
flag
==
HAS_NULL
)
{
pIter
->
cv
=
COL_VAL_NULL
(
pTColumn
->
type
,
pTColumn
->
colId
);
goto
_exit
;
}
(
*
ppTSchema
)
->
numOfCols
=
ncols
;
(
*
ppTSchema
)
->
version
=
sver
;
(
*
ppTSchema
)
->
flen
=
0
;
(
*
ppTSchema
)
->
vlen
=
0
;
(
*
ppTSchema
)
->
tlen
=
0
;
if
(
pIter
->
pRow
->
flag
&
0xf0
)
{
// KV
if
(
pIter
->
iCol
<
pIter
->
pIdx
->
nCol
)
{
uint8_t
*
pData
;
for
(
int32_t
iCol
=
0
;
iCol
<
ncols
;
iCol
++
)
{
SSchema
*
pColumn
=
&
pSchema
[
iCol
];
STColumn
*
pTColumn
=
&
((
*
ppTSchema
)
->
columns
[
iCol
]);
if
(
pIter
->
pRow
->
flag
&
KV_FLG_LIT
)
{
pData
=
pIter
->
pv
+
((
uint8_t
*
)
pIter
->
pIdx
->
idx
)[
pIter
->
iCol
];
}
else
if
(
pIter
->
pRow
->
flag
&
KV_FLG_MID
)
{
pData
=
pIter
->
pv
+
((
uint16_t
*
)
pIter
->
pIdx
->
idx
)[
pIter
->
iCol
];
}
else
{
pData
=
pIter
->
pv
+
((
uint32_t
*
)
pIter
->
pIdx
->
idx
)[
pIter
->
iCol
];
}
pTColumn
->
colId
=
pColumn
->
colId
;
pTColumn
->
type
=
pColumn
->
type
;
pTColumn
->
flags
=
pColumn
->
flags
;
pTColumn
->
bytes
=
pColumn
->
bytes
;
pTColumn
->
offset
=
(
*
ppTSchema
)
->
flen
;
int16_t
cid
;
pData
+=
tGetI16v
(
pData
,
&
cid
);
// skip first column
if
(
iCol
)
{
(
*
ppTSchema
)
->
flen
+=
TYPE_BYTES
[
pColumn
->
type
];
if
(
IS_VAR_DATA_TYPE
(
pColumn
->
type
))
{
(
*
ppTSchema
)
->
vlen
+=
(
pColumn
->
bytes
+
5
);
if
(
TABS
(
cid
)
==
pTColumn
->
colId
)
{
if
(
cid
<
0
)
{
pIter
->
cv
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
}
else
{
pIter
->
cv
.
cid
=
pTColumn
->
colId
;
pIter
->
cv
.
type
=
pTColumn
->
type
;
pIter
->
cv
.
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
pData
+=
tGetU32v
(
pData
,
&
pIter
->
cv
.
value
.
nData
);
if
(
pIter
->
cv
.
value
.
nData
>
0
)
{
pIter
->
cv
.
value
.
pData
=
pData
;
}
else
{
pIter
->
cv
.
value
.
pData
=
NULL
;
}
}
else
{
memcpy
(
&
pIter
->
cv
.
value
.
val
,
pData
,
pTColumn
->
bytes
);
}
}
return
0
;
}
pIter
->
iCol
++
;
goto
_exit
;
}
else
if
(
TABS
(
cid
)
>
pTColumn
->
colId
)
{
pIter
->
cv
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
goto
_exit
;
}
else
{
ASSERT
(
0
);
}
}
else
{
pIter
->
cv
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
goto
_exit
;
}
}
else
{
// Tuple
uint8_t
bv
=
ROW_BIT_VALUE
;
if
(
pIter
->
pb
)
{
switch
(
pIter
->
pRow
->
flag
)
{
case
(
HAS_NULL
|
HAS_NONE
):
bv
=
GET_BIT1
(
pIter
->
pb
,
pIter
->
iTColumn
-
1
);
break
;
case
(
HAS_VALUE
|
HAS_NONE
):
bv
=
GET_BIT1
(
pIter
->
pb
,
pIter
->
iTColumn
-
1
);
if
(
bv
)
bv
++
;
break
;
case
(
HAS_VALUE
|
HAS_NULL
):
bv
=
GET_BIT1
(
pIter
->
pb
,
pIter
->
iTColumn
-
1
)
+
1
;
break
;
case
(
HAS_VALUE
|
HAS_NULL
|
HAS_NONE
):
bv
=
GET_BIT2
(
pIter
->
pb
,
pIter
->
iTColumn
-
1
);
break
;
default:
ASSERT
(
0
);
break
;
}
void
tTSchemaDestroy
(
STSchema
*
pTSchema
)
{
if
(
pTSchema
)
taosMemoryFree
(
pTSchema
);
if
(
bv
==
ROW_BIT_NONE
)
{
pIter
->
cv
=
COL_VAL_NONE
(
pTColumn
->
colId
,
pTColumn
->
type
);
goto
_exit
;
}
else
if
(
bv
==
ROW_BIT_NULL
)
{
pIter
->
cv
=
COL_VAL_NULL
(
pTColumn
->
colId
,
pTColumn
->
type
);
goto
_exit
;
}
}
pIter
->
cv
.
cid
=
pTColumn
->
colId
;
pIter
->
cv
.
type
=
pTColumn
->
type
;
pIter
->
cv
.
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
uint8_t
*
pData
=
pIter
->
pv
+
*
(
int32_t
*
)(
pIter
->
pf
+
pTColumn
->
offset
);
pData
+=
tGetU32v
(
pData
,
&
pIter
->
cv
.
value
.
nData
);
if
(
pIter
->
cv
.
value
.
nData
>
0
)
{
pIter
->
cv
.
value
.
pData
=
pData
;
}
else
{
pIter
->
cv
.
value
.
pData
=
NULL
;
}
}
else
{
memcpy
(
&
pIter
->
cv
.
value
.
val
,
pIter
->
pv
+
pTColumn
->
offset
,
pTColumn
->
bytes
);
}
goto
_exit
;
}
_exit:
pIter
->
iTColumn
++
;
return
&
pIter
->
cv
;
}
// STSchema ========================================
// STag ========================================
static
int
tTagValCmprFn
(
const
void
*
p1
,
const
void
*
p2
)
{
if
(((
STagVal
*
)
p1
)
->
cid
<
((
STagVal
*
)
p2
)
->
cid
)
{
...
...
@@ -1042,7 +1108,6 @@ void tdResetTSchemaBuilder(STSchemaBuilder *pBuilder, schema_ver_t version) {
pBuilder
->
nCols
=
0
;
pBuilder
->
tlen
=
0
;
pBuilder
->
flen
=
0
;
pBuilder
->
vlen
=
0
;
pBuilder
->
version
=
version
;
}
...
...
@@ -1061,24 +1126,21 @@ int32_t tdAddColToSchema(STSchemaBuilder *pBuilder, int8_t type, int8_t flags, c
pCol
->
colId
=
colId
;
pCol
->
flags
=
flags
;
if
(
pBuilder
->
nCols
==
0
)
{
pCol
->
offset
=
0
;
pCol
->
offset
=
-
1
;
}
else
{
STColumn
*
pTCol
=
&
(
pBuilder
->
columns
[
pBuilder
->
nCols
-
1
])
;
p
Col
->
offset
=
pTCol
->
offset
+
TYPE_BYTES
[
pTCol
->
type
];
pCol
->
offset
=
pBuilder
->
flen
;
p
Builder
->
flen
+=
TYPE_BYTES
[
type
];
}
if
(
IS_VAR_DATA_TYPE
(
type
))
{
pCol
->
bytes
=
bytes
;
pBuilder
->
tlen
+=
(
TYPE_BYTES
[
type
]
+
bytes
);
pBuilder
->
vlen
+=
bytes
-
sizeof
(
VarDataLenT
);
}
else
{
pCol
->
bytes
=
TYPE_BYTES
[
type
];
pBuilder
->
tlen
+=
TYPE_BYTES
[
type
];
pBuilder
->
vlen
+=
TYPE_BYTES
[
type
];
}
pBuilder
->
nCols
++
;
pBuilder
->
flen
+=
TYPE_BYTES
[
type
];
ASSERT
(
pCol
->
offset
<
pBuilder
->
flen
);
...
...
@@ -1097,7 +1159,6 @@ STSchema *tdGetSchemaFromBuilder(STSchemaBuilder *pBuilder) {
pSchema
->
numOfCols
=
pBuilder
->
nCols
;
pSchema
->
tlen
=
pBuilder
->
tlen
;
pSchema
->
flen
=
pBuilder
->
flen
;
pSchema
->
vlen
=
pBuilder
->
vlen
;
#ifdef TD_SUPPORT_BITMAP
pSchema
->
tlen
+=
(
int
)
TD_BITMAP_BYTES
(
pSchema
->
numOfCols
);
...
...
@@ -1110,6 +1171,43 @@ STSchema *tdGetSchemaFromBuilder(STSchemaBuilder *pBuilder) {
#endif
STSchema
*
tBuildTSchema
(
SSchema
*
aSchema
,
int32_t
numOfCols
,
int32_t
version
)
{
STSchema
*
pTSchema
=
taosMemoryCalloc
(
1
,
sizeof
(
STSchema
)
+
sizeof
(
STColumn
)
*
numOfCols
);
if
(
pTSchema
==
NULL
)
return
NULL
;
pTSchema
->
numOfCols
=
numOfCols
;
pTSchema
->
version
=
version
;
// timestamp column
ASSERT
(
aSchema
[
0
].
type
==
TSDB_DATA_TYPE_TIMESTAMP
);
ASSERT
(
aSchema
[
0
].
colId
==
PRIMARYKEY_TIMESTAMP_COL_ID
);
pTSchema
->
columns
[
0
].
colId
=
aSchema
[
0
].
colId
;
pTSchema
->
columns
[
0
].
type
=
aSchema
[
0
].
type
;
pTSchema
->
columns
[
0
].
flags
=
aSchema
[
0
].
flags
;
pTSchema
->
columns
[
0
].
bytes
=
aSchema
[
0
].
bytes
;
pTSchema
->
columns
[
0
].
offset
=
-
1
;
// other columns
for
(
int32_t
iCol
=
1
;
iCol
<
numOfCols
;
iCol
++
)
{
SSchema
*
pSchema
=
&
aSchema
[
iCol
];
STColumn
*
pTColumn
=
&
pTSchema
->
columns
[
iCol
];
pTColumn
->
colId
=
pSchema
->
colId
;
pTColumn
->
type
=
pSchema
->
type
;
pTColumn
->
flags
=
pSchema
->
flags
;
pTColumn
->
bytes
=
pSchema
->
bytes
;
pTColumn
->
offset
=
pTSchema
->
flen
;
pTSchema
->
flen
+=
TYPE_BYTES
[
pTColumn
->
type
];
}
return
pTSchema
;
}
void
tDestroyTSchema
(
STSchema
*
pTSchema
)
{
if
(
pTSchema
)
taosMemoryFree
(
pTSchema
);
}
// SColData ========================================
void
tColDataDestroy
(
void
*
ph
)
{
SColData
*
pColData
=
(
SColData
*
)
ph
;
...
...
@@ -1496,7 +1594,7 @@ static FORCE_INLINE void tColDataGetValue4(SColData *pColData, int32_t iVal, SCo
}
value
.
pData
=
pColData
->
pData
+
pColData
->
aOffset
[
iVal
];
}
else
{
tGetValue
(
pColData
->
pData
+
tDataTypes
[
pColData
->
type
].
bytes
*
iVal
,
&
value
,
pColData
->
type
);
memcpy
(
&
value
.
val
,
pColData
->
pData
+
tDataTypes
[
pColData
->
type
].
bytes
*
iVal
,
tDataTypes
[
pColData
->
type
].
bytes
);
}
*
pColVal
=
COL_VAL_VALUE
(
pColData
->
cid
,
pColData
->
type
,
value
);
}
...
...
source/common/src/trow.c
浏览文件 @
ba621647
...
...
@@ -192,7 +192,7 @@ bool tdSTpRowGetVal(STSRow *pRow, col_id_t colId, col_type_t colType, int32_t fl
return
true
;
}
void
*
pBitmap
=
tdGetBitmapAddrTp
(
pRow
,
flen
);
tdGetTpRowValOfCol
(
pVal
,
pRow
,
pBitmap
,
colType
,
offset
-
sizeof
(
TSKEY
)
,
colIdx
);
tdGetTpRowValOfCol
(
pVal
,
pRow
,
pBitmap
,
colType
,
offset
,
colIdx
);
return
true
;
}
...
...
@@ -217,7 +217,7 @@ bool tdSTSRowIterFetch(STSRowIter *pIter, col_id_t colId, col_type_t colType, SC
return
false
;
}
}
tdSTSRowIterGetTpVal
(
pIter
,
pCol
->
type
,
pCol
->
offset
-
sizeof
(
TSKEY
)
,
pVal
);
tdSTSRowIterGetTpVal
(
pIter
,
pCol
->
type
,
pCol
->
offset
,
pVal
);
++
pIter
->
colIdx
;
}
else
if
(
TD_IS_KV_ROW
(
pIter
->
pRow
))
{
return
tdSTSRowIterGetKvVal
(
pIter
,
colId
,
&
pIter
->
kvIdx
,
pVal
);
...
...
@@ -244,7 +244,7 @@ bool tdSTSRowIterNext(STSRowIter *pIter, SCellVal *pVal) {
}
if
(
TD_IS_TP_ROW
(
pIter
->
pRow
))
{
tdSTSRowIterGetTpVal
(
pIter
,
pCol
->
type
,
pCol
->
offset
-
sizeof
(
TSKEY
)
,
pVal
);
tdSTSRowIterGetTpVal
(
pIter
,
pCol
->
type
,
pCol
->
offset
,
pVal
);
}
else
if
(
TD_IS_KV_ROW
(
pIter
->
pRow
))
{
tdSTSRowIterGetKvVal
(
pIter
,
pCol
->
colId
,
&
pIter
->
kvIdx
,
pVal
);
}
else
{
...
...
@@ -469,7 +469,7 @@ bool tdSTSRowGetVal(STSRowIter *pIter, col_id_t colId, col_type_t colType, SCell
#ifdef TD_SUPPORT_BITMAP
colIdx
=
POINTER_DISTANCE
(
pCol
,
pSchema
->
columns
)
/
sizeof
(
STColumn
);
#endif
tdGetTpRowValOfCol
(
pVal
,
pRow
,
pIter
->
pBitmap
,
pCol
->
type
,
pCol
->
offset
-
sizeof
(
TSKEY
)
,
colIdx
-
1
);
tdGetTpRowValOfCol
(
pVal
,
pRow
,
pIter
->
pBitmap
,
pCol
->
type
,
pCol
->
offset
,
colIdx
-
1
);
}
else
if
(
TD_IS_KV_ROW
(
pRow
))
{
SKvRowIdx
*
pIdx
=
(
SKvRowIdx
*
)
taosbsearch
(
&
colId
,
TD_ROW_COL_IDX
(
pRow
),
tdRowGetNCols
(
pRow
),
sizeof
(
SKvRowIdx
),
compareKvRowColId
,
TD_EQ
);
...
...
@@ -757,11 +757,10 @@ int32_t tdAppendColValToKvRow(SRowBuilder *pBuilder, TDRowValT valType, const vo
int32_t
tdAppendColValToTpRow
(
SRowBuilder
*
pBuilder
,
TDRowValT
valType
,
const
void
*
val
,
bool
isCopyVarData
,
int8_t
colType
,
int16_t
colIdx
,
int32_t
offset
)
{
if
(
(
offset
<
(
int32_t
)
sizeof
(
TSKEY
))
||
(
colIdx
<
1
)
)
{
if
(
colIdx
<
1
)
{
terrno
=
TSDB_CODE_INVALID_PARA
;
return
terrno
;
}
offset
-=
sizeof
(
TSKEY
);
--
colIdx
;
#ifdef TD_SUPPORT_BITMAP
...
...
@@ -853,7 +852,7 @@ int32_t tdSRowResetBuf(SRowBuilder *pBuilder, void *pBuf) {
memset
(
pBuilder
->
pBitmap
,
TD_VTYPE_NONE_BYTE_II
,
pBuilder
->
nBitmaps
);
#endif
// the primary TS key is stored separatedly
len
=
TD_ROW_HEAD_LEN
+
pBuilder
->
flen
-
sizeof
(
TSKEY
)
+
pBuilder
->
nBitmaps
;
len
=
TD_ROW_HEAD_LEN
+
pBuilder
->
flen
+
pBuilder
->
nBitmaps
;
TD_ROW_SET_LEN
(
pBuilder
->
pBuf
,
len
);
TD_ROW_SET_SVER
(
pBuilder
->
pBuf
,
pBuilder
->
sver
);
break
;
...
...
source/common/src/ttypes.c
浏览文件 @
ba621647
...
...
@@ -61,7 +61,7 @@ tDataTypeDescriptor tDataTypes[TSDB_DATA_TYPE_MAX] = {
static
float
floatMin
=
-
FLT_MAX
,
floatMax
=
FLT_MAX
;
static
double
doubleMin
=
-
DBL_MAX
,
doubleMax
=
DBL_MAX
;
FORCE_INLINE
void
*
getDataMin
(
int32_t
type
,
void
*
value
)
{
FORCE_INLINE
void
*
getDataMin
(
int32_t
type
,
void
*
value
)
{
switch
(
type
)
{
case
TSDB_DATA_TYPE_FLOAT
:
*
(
float
*
)
value
=
floatMin
;
...
...
@@ -77,7 +77,7 @@ FORCE_INLINE void *getDataMin(int32_t type, void* value) {
return
value
;
}
FORCE_INLINE
void
*
getDataMax
(
int32_t
type
,
void
*
value
)
{
FORCE_INLINE
void
*
getDataMax
(
int32_t
type
,
void
*
value
)
{
switch
(
type
)
{
case
TSDB_DATA_TYPE_FLOAT
:
*
(
float
*
)
value
=
floatMax
;
...
...
source/dnode/vnode/src/inc/tsdb.h
浏览文件 @
ba621647
...
...
@@ -56,7 +56,7 @@ typedef struct SDataFWriter SDataFWriter;
typedef
struct
SDataFReader
SDataFReader
;
typedef
struct
SDelFWriter
SDelFWriter
;
typedef
struct
SDelFReader
SDelFReader
;
typedef
struct
S
RowIter
S
RowIter
;
typedef
struct
S
TSDBRowIter
STSDB
RowIter
;
typedef
struct
STsdbFS
STsdbFS
;
typedef
struct
SRowMerger
SRowMerger
;
typedef
struct
STsdbReadSnap
STsdbReadSnap
;
...
...
@@ -111,9 +111,9 @@ static FORCE_INLINE int64_t tsdbLogicToFileSize(int64_t lSize, int32_t szPage) {
void
tsdbRowGetColVal
(
TSDBROW
*
pRow
,
STSchema
*
pTSchema
,
int32_t
iCol
,
SColVal
*
pColVal
);
// int32_t tPutTSDBRow(uint8_t *p, TSDBROW *pRow);
int32_t
tsdbRowCmprFn
(
const
void
*
p1
,
const
void
*
p2
);
// SRowIter
void
t
RowIterInit
(
S
RowIter
*
pIter
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
);
SColVal
*
t
RowIterNext
(
S
RowIter
*
pIter
);
// S
TSDB
RowIter
void
t
sdbRowIterInit
(
STSDB
RowIter
*
pIter
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
);
SColVal
*
t
sdbRowIterNext
(
STSDB
RowIter
*
pIter
);
// SRowMerger
int32_t
tRowMergerInit2
(
SRowMerger
*
pMerger
,
STSchema
*
pResTSchema
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
);
int32_t
tRowMergerAdd
(
SRowMerger
*
pMerger
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
);
...
...
@@ -562,7 +562,7 @@ struct SDFileSet {
SSttFile
*
aSttF
[
TSDB_MAX_STT_TRIGGER
];
};
struct
SRowIter
{
struct
S
TSDB
RowIter
{
TSDBROW
*
pRow
;
STSchema
*
pTSchema
;
SColVal
colVal
;
...
...
source/dnode/vnode/src/tsdb/tsdbCommit.c
浏览文件 @
ba621647
...
...
@@ -341,7 +341,7 @@ int32_t tsdbUpdateTableSchema(SMeta *pMeta, int64_t suid, int64_t uid, SSkmInfo
pSkmInfo
->
suid
=
suid
;
pSkmInfo
->
uid
=
uid
;
t
TSchemaDestroy
(
pSkmInfo
->
pTSchema
);
t
DestroyTSchema
(
pSkmInfo
->
pTSchema
);
code
=
metaGetTbTSchemaEx
(
pMeta
,
suid
,
uid
,
-
1
,
&
pSkmInfo
->
pTSchema
);
TSDB_CHECK_CODE
(
code
,
lino
,
_exit
);
...
...
@@ -365,7 +365,7 @@ static int32_t tsdbCommitterUpdateRowSchema(SCommitter *pCommitter, int64_t suid
pCommitter
->
skmRow
.
suid
=
suid
;
pCommitter
->
skmRow
.
uid
=
uid
;
t
TSchemaDestroy
(
pCommitter
->
skmRow
.
pTSchema
);
t
DestroyTSchema
(
pCommitter
->
skmRow
.
pTSchema
);
code
=
metaGetTbTSchemaEx
(
pCommitter
->
pTsdb
->
pVnode
->
pMeta
,
suid
,
uid
,
sver
,
&
pCommitter
->
skmRow
.
pTSchema
);
TSDB_CHECK_CODE
(
code
,
lino
,
_exit
);
...
...
@@ -623,7 +623,8 @@ int32_t tsdbWriteDataBlock(SDataFWriter *pWriter, SBlockData *pBlockData, SMapDa
_exit:
if
(
code
)
{
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
}
return
code
;
}
...
...
@@ -666,7 +667,8 @@ int32_t tsdbWriteSttBlock(SDataFWriter *pWriter, SBlockData *pBlockData, SArray
_exit:
if
(
code
)
{
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
}
return
code
;
}
...
...
@@ -706,7 +708,8 @@ static int32_t tsdbCommitSttBlk(SDataFWriter *pWriter, SDiskDataBuilder *pBuilde
_exit:
if
(
code
)
{
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
tsdbError
(
"vgId:%d, %s failed at line %d since %s"
,
TD_VID
(
pWriter
->
pTsdb
->
pVnode
),
__func__
,
lino
,
tstrerror
(
code
));
}
return
code
;
}
...
...
@@ -919,8 +922,8 @@ static void tsdbCommitDataEnd(SCommitter *pCommitter) {
#else
tBlockDataDestroy
(
&
pCommitter
->
dWriter
.
bDatal
,
1
);
#endif
t
TSchemaDestroy
(
pCommitter
->
skmTable
.
pTSchema
);
t
TSchemaDestroy
(
pCommitter
->
skmRow
.
pTSchema
);
t
DestroyTSchema
(
pCommitter
->
skmTable
.
pTSchema
);
t
DestroyTSchema
(
pCommitter
->
skmRow
.
pTSchema
);
}
static
int32_t
tsdbCommitData
(
SCommitter
*
pCommitter
)
{
...
...
source/dnode/vnode/src/tsdb/tsdbDiskData.c
浏览文件 @
ba621647
...
...
@@ -595,21 +595,21 @@ int32_t tDiskDataAddRow(SDiskDataBuilder *pBuilder, TSDBROW *pRow, STSchema *pTS
if
(
pBuilder
->
bi
.
minKey
>
kRow
.
ts
)
pBuilder
->
bi
.
minKey
=
kRow
.
ts
;
if
(
pBuilder
->
bi
.
maxKey
<
kRow
.
ts
)
pBuilder
->
bi
.
maxKey
=
kRow
.
ts
;
SRowIter
iter
=
{
0
};
tRowIterInit
(
&
iter
,
pRow
,
pTSchema
);
S
TSDB
RowIter
iter
=
{
0
};
t
sdb
RowIterInit
(
&
iter
,
pRow
,
pTSchema
);
SColVal
*
pColVal
=
tRowIterNext
(
&
iter
);
SColVal
*
pColVal
=
t
sdb
RowIterNext
(
&
iter
);
for
(
int32_t
iBuilder
=
0
;
iBuilder
<
pBuilder
->
nBuilder
;
iBuilder
++
)
{
SDiskColBuilder
*
pDCBuilder
=
(
SDiskColBuilder
*
)
taosArrayGet
(
pBuilder
->
aBuilder
,
iBuilder
);
while
(
pColVal
&&
pColVal
->
cid
<
pDCBuilder
->
cid
)
{
pColVal
=
tRowIterNext
(
&
iter
);
pColVal
=
t
sdb
RowIterNext
(
&
iter
);
}
if
(
pColVal
&&
pColVal
->
cid
==
pDCBuilder
->
cid
)
{
code
=
tDiskColAddVal
(
pDCBuilder
,
pColVal
);
if
(
code
)
return
code
;
pColVal
=
tRowIterNext
(
&
iter
);
pColVal
=
t
sdb
RowIterNext
(
&
iter
);
}
else
{
code
=
tDiskColAddVal
(
pDCBuilder
,
&
COL_VAL_NONE
(
pDCBuilder
->
cid
,
pDCBuilder
->
type
));
if
(
code
)
return
code
;
...
...
source/dnode/vnode/src/tsdb/tsdbSnapshot.c
浏览文件 @
ba621647
...
...
@@ -555,7 +555,7 @@ int32_t tsdbSnapReaderClose(STsdbSnapReader** ppReader) {
}
tBlockDataDestroy
(
&
pReader
->
bData
,
1
);
t
TSchemaDestroy
(
pReader
->
skmTable
.
pTSchema
);
t
DestroyTSchema
(
pReader
->
skmTable
.
pTSchema
);
// del
if
(
pReader
->
pDelFReader
)
tsdbDelFReaderClose
(
&
pReader
->
pDelFReader
);
...
...
@@ -1416,7 +1416,7 @@ int32_t tsdbSnapWriterClose(STsdbSnapWriter** ppWriter, int8_t rollback) {
taosArrayDestroy
(
pWriter
->
dReader
.
aBlockIdx
);
tBlockDataDestroy
(
&
pWriter
->
bData
,
1
);
t
TSchemaDestroy
(
pWriter
->
skmTable
.
pTSchema
);
t
DestroyTSchema
(
pWriter
->
skmTable
.
pTSchema
);
for
(
int32_t
iBuf
=
0
;
iBuf
<
sizeof
(
pWriter
->
aBuf
)
/
sizeof
(
uint8_t
*
);
iBuf
++
)
{
tFree
(
pWriter
->
aBuf
[
iBuf
]);
...
...
source/dnode/vnode/src/tsdb/tsdbUtil.c
浏览文件 @
ba621647
...
...
@@ -579,8 +579,8 @@ int32_t tsdbRowCmprFn(const void *p1, const void *p2) {
return
tsdbKeyCmprFn
(
&
TSDBROW_KEY
((
TSDBROW
*
)
p1
),
&
TSDBROW_KEY
((
TSDBROW
*
)
p2
));
}
// SRowIter ======================================================
void
t
RowIterInit
(
S
RowIter
*
pIter
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
)
{
// S
TSDB
RowIter ======================================================
void
t
sdbRowIterInit
(
STSDB
RowIter
*
pIter
,
TSDBROW
*
pRow
,
STSchema
*
pTSchema
)
{
pIter
->
pRow
=
pRow
;
if
(
pRow
->
type
==
0
)
{
ASSERT
(
pTSchema
);
...
...
@@ -594,7 +594,7 @@ void tRowIterInit(SRowIter *pIter, TSDBROW *pRow, STSchema *pTSchema) {
}
}
SColVal
*
t
RowIterNext
(
S
RowIter
*
pIter
)
{
SColVal
*
t
sdbRowIterNext
(
STSDB
RowIter
*
pIter
)
{
if
(
pIter
->
pRow
->
type
==
0
)
{
if
(
pIter
->
i
<
pIter
->
pTSchema
->
numOfCols
)
{
tTSRowGetVal
(
pIter
->
pRow
->
pTSRow
,
pIter
->
pTSchema
,
pIter
->
i
,
&
pIter
->
colVal
);
...
...
@@ -1084,11 +1084,11 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
cv
.
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
void
*
pData
=
(
char
*
)
pRow
+
*
(
int32_t
*
)(
pRow
->
data
+
pTColumn
->
offset
-
sizeof
(
TSKEY
)
);
void
*
pData
=
(
char
*
)
pRow
+
*
(
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
-
sizeof
(
TSKEY
)
,
pTColumn
->
bytes
);
memcpy
(
&
cv
.
value
.
val
,
pRow
->
data
+
pTColumn
->
offset
,
pTColumn
->
bytes
);
}
code
=
tColDataAppendValue
(
pColData
,
&
cv
);
...
...
@@ -1106,11 +1106,11 @@ static int32_t tBlockDataAppendTPRow(SBlockData *pBlockData, STSRow *pRow, STSch
cv
.
flag
=
CV_FLAG_VALUE
;
if
(
IS_VAR_DATA_TYPE
(
pTColumn
->
type
))
{
void
*
pData
=
(
char
*
)
pRow
+
*
(
int32_t
*
)(
pRow
->
data
+
pTColumn
->
offset
-
sizeof
(
TSKEY
)
);
void
*
pData
=
(
char
*
)
pRow
+
*
(
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
-
sizeof
(
TSKEY
)
,
pTColumn
->
bytes
);
memcpy
(
&
cv
.
value
.
val
,
pRow
->
data
+
pTColumn
->
offset
,
pTColumn
->
bytes
);
}
code
=
tColDataAppendValue
(
pColData
,
&
cv
);
...
...
source/libs/parser/src/parInsertUtil.c
浏览文件 @
ba621647
...
...
@@ -139,8 +139,8 @@ void insSetBoundColumnInfo(SParsedDataColInfo* pColList, SSchema* pSchema, col_i
if
(
i
>
0
)
{
pColList
->
cols
[
i
].
offset
=
pColList
->
cols
[
i
-
1
].
offset
+
pSchema
[
i
-
1
].
bytes
;
pColList
->
cols
[
i
].
toffset
=
pColList
->
flen
;
}
pColList
->
flen
+=
TYPE_BYTES
[
type
];
}
switch
(
type
)
{
case
TSDB_DATA_TYPE_BINARY
:
pColList
->
allNullLen
+=
(
VARSTR_HEADER_SIZE
+
CHAR_BYTES
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录