enh: row optimization

This commit is contained in:
Cary Xu 2022-08-03 16:33:53 +08:00
parent 2b06d8328c
commit 22512c0922
2 changed files with 7 additions and 8 deletions

View File

@ -150,8 +150,8 @@ typedef struct {
void *pBitmap;
void *pOffset;
int32_t extendedRowSize;
int16_t nNone;
int16_t nNull;
bool hasNone;
bool hasNull;
} SRowBuilder;
#define TD_ROW_HEAD_LEN (sizeof(STSRow))
@ -292,7 +292,7 @@ int32_t tdSRowSetExtendedInfo(SRowBuilder *pBuilder, int32_t nCols, int32_t nBou
int32_t tdSRowResetBuf(SRowBuilder *pBuilder, void *pBuf);
static FORCE_INLINE void tdSRowEnd(SRowBuilder *pBuilder) {
STSRow *pRow = (STSRow *)pBuilder->pBuf;
if (pBuilder->nNone || pBuilder->nNull) {
if (pBuilder->hasNull || pBuilder->hasNone) {
pRow->statis = 1;
}
}

View File

@ -925,10 +925,10 @@ int32_t tdAppendColValToRow(SRowBuilder *pBuilder, col_id_t colId, int8_t colTyp
case TD_VTYPE_NORM:
break;
case TD_VTYPE_NULL:
++pBuilder->nNull;
if (!pBuilder->hasNull) pBuilder->hasNull = true;
break;
case TD_VTYPE_NONE:
++pBuilder->nNone;
if (!pBuilder->hasNone) pBuilder->hasNone = true;
break;
default:
ASSERT(0);
@ -1102,10 +1102,9 @@ int32_t tdSRowResetBuf(SRowBuilder *pBuilder, void *pBuf) {
return terrno;
}
if (pBuilder->nNone) pBuilder->nNone = 0;
if (pBuilder->nNull) pBuilder->nNull = 0;
if (pBuilder->hasNone) pBuilder->hasNone = false;
if (pBuilder->hasNull) pBuilder->hasNull = false;
pBuilder->nNull = 0;
TD_ROW_SET_INFO(pBuilder->pBuf, 0);
TD_ROW_SET_TYPE(pBuilder->pBuf, pBuilder->rowType);