From 7e5b12f7d52108ce4c25a1cbf1112c349987b8d8 Mon Sep 17 00:00:00 2001 From: hzcheng Date: Wed, 25 Mar 2020 18:00:18 +0800 Subject: [PATCH] TD-34 --- src/common/inc/dataformat.h | 20 +++++++++++--- src/common/src/dataformat.c | 51 +++++++++++++++++++++++++++++++---- src/vnode/tsdb/src/tsdbMain.c | 28 ++++++++++++++++--- 3 files changed, 88 insertions(+), 11 deletions(-) diff --git a/src/common/inc/dataformat.h b/src/common/inc/dataformat.h index 1f46c68abc..207ff4dbfd 100644 --- a/src/common/inc/dataformat.h +++ b/src/common/inc/dataformat.h @@ -105,11 +105,25 @@ SDataRow tdDataRowDup(SDataRow row); // ----------------- Data column structure typedef struct SDataCol { - int64_t len; - char data[]; + int32_t len; + void * pData; } SDataCol; -void tdConvertDataRowToCol(SDataCol *cols, STSchema *pSchema, int *iter); +typedef struct { + TSKEY firstKey; + TSKEY lastKey; + int numOfPoints; + int numOfCols; + void * buf; + SDataCol cols[]; +} SDataCols; + +#define keyCol(cols) (&((cols)->cols[0])) // Key column + +SDataCols *tdNewDataCols(STSchema *pSchema, int nRows); +void tdFreeDataCols(SDataCols *pCols); +void tdResetDataCols(SDataCols *pCols); +void tdAppendDataRowToDataCol(SDataRow row, SDataCols *pCols, STSchema *pSchema); #ifdef __cplusplus } diff --git a/src/common/src/dataformat.c b/src/common/src/dataformat.c index 04826e43ac..3c692f9eba 100644 --- a/src/common/src/dataformat.c +++ b/src/common/src/dataformat.c @@ -294,14 +294,55 @@ SDataRow tdDataRowDup(SDataRow row) { return trow; } -void tdConvertDataRowToCol(SDataCol *cols, STSchema *pSchema, int *iter) { - int row = *iter; +SDataCols *tdNewDataCols(STSchema *pSchema, int nRows) { + int nCols = schemaNCols(pSchema); + + SDataCols *pInfo = (SDataCols *)calloc(1, sizeof(SDataCols) + sizeof(SDataCol) * nCols); + if (pInfo == NULL) return NULL; + + pInfo->numOfCols = nCols; + pInfo->firstKey = INT64_MIN; + pInfo->lastKey = INT64_MAX; + pInfo->buf = malloc(tdMaxRowBytesFromSchema(pSchema) * nRows); + if (pInfo->buf == NULL) { + free(pInfo); + return NULL; + } - for (int i = 0; i < schemaNCols(pSchema); i++) { - // TODO + pInfo->cols[0].pData = pInfo->buf; + for (int i = 1; i < nCols; i++) { + pInfo->cols[i].pData = (char *)(pInfo->cols[i - 1].pData) + schemaColAt(pSchema, i - 1)->bytes * nRows; } - *iter = row + 1; + return pInfo; +} + +void tdFreeDataCols(SDataCols *pCols) { + if (pCols) { + if (pCols->buf) free(pCols->buf); + free(pCols); + } +} + +void tdResetDataCols(SDataCols *pCols) { + pCols->firstKey = INT64_MAX; + pCols->lastKey = INT64_MIN; + pCols->numOfPoints = 0; + for (int i = 0; i < pCols->numOfCols; i++) { + pCols->cols[i].len = 0; + } +} + +void tdAppendDataRowToDataCol(SDataRow row, SDataCols *pCols, STSchema *pSchema) { + TSKEY key = dataRowKey(row); + if (pCols->numOfPoints == 0) pCols->firstKey = key; + pCols->lastKey = key; + for (int i = 0; i < pCols->numOfCols; i++) { + SDataCol *pCol = pCols->cols + i; + memcpy((void *)((char *)(pCol->pData) + pCol->len), dataRowAt(row, colOffset(schemaColAt(pSchema, i))), + colBytes(schemaColAt(pSchema, i))); + pCol->len += colBytes(schemaColAt(pSchema, i)); + } } /** diff --git a/src/vnode/tsdb/src/tsdbMain.c b/src/vnode/tsdb/src/tsdbMain.c index af3a923d90..7b1836378d 100644 --- a/src/vnode/tsdb/src/tsdbMain.c +++ b/src/vnode/tsdb/src/tsdbMain.c @@ -84,7 +84,7 @@ static int tsdbOpenMetaFile(char *tsdbDir); static int32_t tsdbInsertDataToTable(tsdb_repo_t *repo, SSubmitBlk *pBlock); static int32_t tsdbRestoreCfg(STsdbRepo *pRepo, STsdbCfg *pCfg); static int32_t tsdbGetDataDirName(STsdbRepo *pRepo, char *fname); -static void * tsdbCommitToFile(void *arg); +static void * tsdbCommitData(void *arg); #define TSDB_GET_TABLE_BY_ID(pRepo, sid) (((STSDBRepo *)pRepo)->pTableList)[sid] #define TSDB_GET_TABLE_BY_NAME(pRepo, name) @@ -327,7 +327,7 @@ int32_t tsdbTriggerCommit(tsdb_repo_t *repo) { pRepo->tsdbCache->curBlock = NULL; // TODO: here should set as detached or use join for memory leak - pthread_create(&(pRepo->commitThread), NULL, tsdbCommitToFile, (void *)repo); + pthread_create(&(pRepo->commitThread), NULL, tsdbCommitData, (void *)repo); tsdbUnLockRepo(repo); return 0; @@ -816,7 +816,7 @@ static SSkipListIterator **tsdbCreateTableIters(STsdbMeta *pMeta, int maxTables) } // Commit to file -static void *tsdbCommitToFile(void *arg) { +static void *tsdbCommitData(void *arg) { // TODO printf("Starting to commit....\n"); STsdbRepo * pRepo = (STsdbRepo *)arg; @@ -894,4 +894,26 @@ static void *tsdbCommitToFile(void *arg) { tsdbUnLockRepo(arg); return NULL; +} + +static int tsdbCommitToFile(STsdbRepo *pRepo, SSkipListIterator **iters, int fid) { + STsdbMeta * pMeta = pRepo->tsdbMeta; + STsdbFileH *pFileH = pRepo->tsdbFileH; + STsdbCfg * pCfg = &pRepo->config; + TSKEY minKey = 0, maxKey = 0; + tsdbGetKeyRangeOfFileId(pCfg->daysPerFile, pCfg->precision, fid, &minKey, &maxKey); + + for (int tid = 0; tid < pCfg->maxTables; tid++) { + STable *pTable = pMeta->tables[tid]; + SSkipListIterator *pIter = iters[tid]; + + if (pIter == NULL) continue; + + // Read data + // while () { + + // } + } + + return 0; } \ No newline at end of file -- GitLab