TDengine/source/libs/new-stream/inc/streamTriggerMerger.h
WANG MINGMING 558928cbe1
feat(stream): optimize stream logic (#33027)
* fix: remove debug log

* fix: remove assert

* fix: delete unused code

* enh: [TD-37251] Support expr in state window.

* feat(stream): support expr in state window trigger

* enh: [TD-37251] Fix SCL_IS_CONST_CALC condition.

* fix(stream): set ver in wal

* fix: print code

* fix: increase runner replica num

* fix: trigger mem error

* fix: sliding _tnext_ts value

* fix(stream): disable tagFilterCache in stream reader trigger

* fix: crash

* Revert "fix(stream): fix history calc finish check"

This reverts commit f93d17f1d2.

* Revert "fix(stream): fix calc request allocation in trigger"

This reverts commit c5410f6da0.

* fix(stream): fix calc request allocation in trigger

* enh: [TD-37251] External window support more placeholder.

* fix(stream): modify size of return from 1000000->4096

* enh: [TD-37251] Modify error msg when stream query do not have from clause.

* fix(stream): add log for group not found

* fix(stream): do not return gid=0 in walMetaData interface

* enh: [TD-37251] Fix missing ts column in vtable query.

* fix: test case build failed

* fix: invalid read issue

* fix(stream): add vtable logic

* fix(stream): encode error in wal

* fix(stream): add vtable logic

* fix(stream): add log

* fix: diff funcition crash

* Revert "Merge branch 'enh/TD-37251-3.0-dropoutput' into enh/TD-37251-3.0"

This reverts commit e93cbd6fd4, reversing
changes made to dc3230591d.

* Revert "Merge branch 'enh/TD-37251-3.0-vtable' into enh/TD-37251-3.0"

This reverts commit dc3230591d, reversing
changes made to 085e086782.

* fix(stream): fix block data len is too large if data type is vchar

* fix: drop output table

* feat: runner delete output table

* process pDropBlock in trigger task.

* fix(stream): opti log level

* fix(stream): build block for drop table

* fix(stream): set gid for normal table

* fix(stream): set gid for normal table

* feat: Support delete output.

* fix(stream): rows error

* fix(stream): memory leak

* enh: [TD-37251] Fix external window wrong ts column.

* fix(stream): fix calc time check in batch mode

* fix: merge aligned external window issue

* Revert "fix(stream): fix calc time check in batch mode"

This reverts commit d895b7f577.

* fix(stream): add test case

* fix(stream): add insert drop table logic

* fix: external window end issue

* fix(stream): add test case

* fix(stream): fix trigger pull data

* fix(stream): fix history calc request

* enh: drop table on snode

* fix(stream): adjust hash index if data is filtered in wal

* fix(stream): rollback

* enh: add merge aligned extwin window row idx

* fix: drop output table

* fix: compile issue

* enh: [TD-37251] Add flag to identify interval window is overlapped

* fix: overlap

* fix(stream): set gid=-1 for initialized

* fix(stream): modify log level

* fix: trigger slow issue

* fix(stream): add basic test for obj pool

* fix(stream): fix metadata clear in trigger

* fix(stream): fix idle runner allocation in trigger

* fix: handle agg output on externalWin

* fix: test case

* fix(stream): adjust log

* fix: reset pCtx pOutput

* fix: memory leak

* fix: search first win for tsCol

* fix(stream): add test case for schema change

* fix: mem leak

* fix: mem leak

* Reapply "Merge branch 'enh/TD-37251-3.0-vtable' into enh/TD-37251-3.0"

This reverts commit b508e66958.

* fix(stream): fix virtual table data pull

* fix(stream): fix set table request

* fix(stream): process empty uidlist

* fix(stream): fix set table request

* fix(stream): fix data new request in trigger

* fix(stream): tablelist error for vtable

* fix(stream): block ver is null

* fix(stream): remove version limition for wal

* fix(stream): block rows error

* fix(stream): fix pending calc param in batch mode

* fix(stream): auto create table

* fix(stream): fix stream vtable data merge

* fix: _tcurrentts

* fix(stream): destroy hash

* fix(stream): fix trigger status

* fix(stream): colId error in vtable

* fix(stream): update nrows of vtable data block

* fix(stream): fix trigger status

* fix(stream): enable low latency calc for period trigger

* fix: test case file path

* fix: test case file path

* fix: string to node in reader

* enh: add test log

* fix(stream): increase wait time of non-low-latency mode

* fix(stream): fix column capacity in scalar calculation

* fix(stream): fix column capacity in trigger expr calculation

* fix: get origTableInfos

* fix(stream): fix calc data pull in trigger

* fix(stream): fix calc data cache write in trigger

* enh: [TD-37251] Add flag to identify interval wind

* fix: external window memory usage issue

* fix(stream): fix epxr result column in trigger

* fix(stream): add metaCache for calc plan

* fix(stream): fix stream obj list clear

* fix(stream): rollback

* enh: [TD-37251] Add flag to identify interval wind

* fix: mem free

* fix(stream): add metaCache for calc plan

* fix(stream): fix calc data cache write in trigger

* fix(stream): fix calc data cache write in trigger

* enh: optimize external result block memory

* fix(stream): modify logic of judge table for create table

* fix(stream): fix event window check in trigger

* fix(stream): fix count window check in trigger

* fix(stream): colSize=0 while encoding block because pDataCol->hasNull is false in secode time & reload table list if create table

* enh: optimize stream memory

* fix(stream): trigger tag error

* fix: add log

* fix(stream): fix calc data write in trigger

* fix: drop output table

* fix(stream): fix max delay in trigger

* fix: drop output table

* fix(stream): fix max delay in trigger

* fix(build): handle return value of function

* fix(stream): read gid error if it is child table in stream

* fix(stream): fix calc param of history calculation

* fix(stream): fix recalc of delete data

* fix(stream): fix calc data of period trigger

* fix(stream): fix cache read check

* fix(stream): filter error in calc plan

* fix: reset externla window expr

* fix(stream): fix calc parm of max delay

* fix: time range and case issues

* fix(stream): fix crash in trigger

* fix: case issues

* fix: fix window node mem leak.

* fix(stream): fix meta data clear in trigger

* fix(stream): table schema is old in TsdbDataRequest for vtable

* fix: fix slingding window place holder check condition.

* Revert "fix: fix slingding window place holder check condition."

This reverts commit ad864a1dc1.

* fix(stream): null pointer error

* fix: case issue

* fix(stream): calc data error for vtable

* fix(stream): fix data sorter in trigger

* fix(stream): add log for delete data

* fix(stream): fix start version of realtime calculation

* fix(stream): fix cache data merger of vtable

* fix: case issues

* fix(ci): upgrade stream cases in test_cols_function

* fix(stream): gid not found if change tag value

* fix: fix slingding window place holder check condition.

* fix(stream): fix virt table info request in trigger

* fix(stream): set gid = uid if stream table type != SUPER table

* fix: clean cache data by group

* fix: add block info and case issues

* fix: fix heap-buffer-overflow.

* fix(stream): fix state window with extend param

* fix: fix access null pointer.

* fix: case issues

* fix: case issue

* fix(stream): fix ignore_nodata_trigger option for period trigger

* fix(stream): fix pseudo col fetch for calc data

* fix: Extend checking time to avoid timeout.

* fix: case issues

* fix(stream): fix group col fetch for virtual tables

* fix(stream): tag is NULL for non vtable

* fix(stream): fix sliding check of virtual table

* test(stream): check stream status after create all streams

* fix: add log

* fix(stream): fix wal meta truncate when ignore disorder

* fix(stream): gid not found for child table

* fix: fix place holder condition pushdown error.

* fix(stream): suid not equal when delete data for child table

* fix: id issue

* fix(stream): disable recalc for count trigger

* fix: cast result rowSize error in project

* fix(stream): add log for tsdb meta

* fix(stream): fix gid in tsdb meta request

* fix(stream): fix wend of unclosed windows

* fix(stream): fix ignore_nodata_trigger option for period trigger

* fix: case issues

* fix(stream): fix calc data pull for empty interval window

* fix: fix ext window condition.

* fix(ci): smaBasic performance check affectd by debug level log

* fix(stream): add suid when set table list for vtable

* fix: forbid using prefilter when using %%trows an trigger table is virtual table.

* fix: forbid prefilter %%trows cases.

* fix(stream): sort cid in tsdbVirtalDataReq

* fix: forbid prefilter %%trows cases.

* fix(stream): add log for virtual table tsdb data

* fix(stream): get delete msg for vtable

* fix: winRowIndex

* Revert "fix: winRowIndex"

This reverts commit e08b41cf96.

* fix(stream): fix data merge in trigger

* test(stream): fix case ans

* fix(stream): fix empty calc data pull for period trigger

* fix(stream): col index error for tsdbVirtalDataReq

* fix(stream): pTableList is NULL for vtable

* test(stream): fix case ans

* fix(stream): fix notification in trigger

* fix(stream): memory leak

* fix(stream): fix virtual data pull in trigger

* test(stream): fix case ans

* fix(stream): col index error for tsdbVirtalDataReq

* fix(stream): pTableList is NULL for vtable

* test(stream): fix case ans

* fix(stream): fix notification in trigger

* fix(stream): memory leak

* fix(stream): fix virtual data pull in trigger

* test(stream): fix case ans

* fix: case issue

* fix: crash issue

* fix: forbid prefilter %%trows cases.

* fix(stream): session case

* fix(stream): fix data pull for virtual tables

* fix(stream): add log

* fix(stream): fix calc req send in batch mode

* fix: fix stream UT

* fix(stream): tablelist is null for non vtable

* fix: mem leak

* fix(stream): fix compile error in trigger

* fix: return code issue

---------

Co-authored-by: dapan1121 <wpan@taosdata.com>
Co-authored-by: facetosea <285808407@qq.com>
Co-authored-by: Jing Sima <simondominic9997@outlook.com>
Co-authored-by: Jinqing Kuang <kuangjinqingcn@gmail.com>
Co-authored-by: Tony Zhang <tonyzhang@taosdata.com>
2025-09-25 15:48:14 +08:00

494 lines
20 KiB
C

/*
* Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
*
* This program is free software: you can use, redistribute, and/or modify
* it under the terms of the GNU Affero General Public License, version 3
* or later ("AGPL"), as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef TDENGINE_STREAM_TRIGGER_MERGER_H
#define TDENGINE_STREAM_TRIGGER_MERGER_H
#ifdef __cplusplus
extern "C" {
#endif
#include "filter.h"
#include "stream.h"
#include "tcommon.h"
#include "tlosertree.h"
#include "tobjpool.h"
struct SStreamTriggerTask;
typedef struct SSTriggerMetaData {
int64_t skey;
int64_t ekey;
int64_t ver;
int64_t nrows;
} SSTriggerMetaData;
typedef struct SSTriggerTableMeta {
int64_t tbUid;
int32_t vgId;
int32_t metaIdx;
SArray *pMetas; // SArray<SSTriggerMetaData>
} SSTriggerTableMeta;
typedef enum ETriggerMetaDataMask {
TRIGGER_META_MASK_SKEY_INACCURATE = BIT_FLAG_MASK(0),
TRIGGER_META_MASK_EKEY_INACCURATE = BIT_FLAG_MASK(1),
TRIGGER_META_MASK_DATA_EMPTY = BIT_FLAG_MASK(2),
} ETriggerMetaDataMask;
#define SET_TRIGGER_META_NROW_INACCURATE(pMeta) \
do { \
if ((pMeta)->nrows >= 0) { \
(pMeta)->nrows = INT64_MIN; \
} \
} while (0)
#define IS_TRIGGER_META_NROW_INACCURATE(pMeta) ((pMeta)->nrows < 0)
#define SET_TRIGGER_META_SKEY_INACCURATE(pMeta) \
do { \
SET_TRIGGER_META_NROW_INACCURATE(pMeta); \
(pMeta)->nrows |= TRIGGER_META_MASK_SKEY_INACCURATE; \
} while (0)
#define IS_TRIGGER_META_SKEY_INACCURATE(pMeta) \
(IS_TRIGGER_META_NROW_INACCURATE(pMeta) && ((pMeta)->nrows & TRIGGER_META_MASK_SKEY_INACCURATE))
#define SET_TRIGGER_META_EKEY_INACCURATE(pMeta) \
do { \
SET_TRIGGER_META_NROW_INACCURATE(pMeta); \
(pMeta)->nrows |= TRIGGER_META_MASK_EKEY_INACCURATE; \
} while (0)
#define IS_TRIGGER_META_EKEY_INACCURATE(pMeta) \
(IS_TRIGGER_META_NROW_INACCURATE(pMeta) && ((pMeta)->nrows & TRIGGER_META_MASK_EKEY_INACCURATE))
#define SET_TRIGGER_META_DATA_EMPTY(pMeta) \
do { \
SET_TRIGGER_META_NROW_INACCURATE(pMeta); \
(pMeta)->nrows |= TRIGGER_META_MASK_DATA_EMPTY; \
} while (0)
#define IS_TRIGGER_META_DATA_EMPTY(pMeta) \
(IS_TRIGGER_META_NROW_INACCURATE(pMeta) && ((pMeta)->nrows & TRIGGER_META_MASK_DATA_EMPTY))
typedef enum ETriggerTimestampSorterMask {
TRIGGER_TS_SORTER_MASK_SORT_INFO_SET = BIT_FLAG_MASK(0),
TRIGGER_TS_SORTER_MASK_META_DATA_SET = BIT_FLAG_MASK(1),
TRIGGER_TS_SORTER_MASK_DATA_MERGER_BUILD = BIT_FLAG_MASK(2),
TRIGGER_TS_SORTER_MASK_SESS_WIN_BUILD = BIT_FLAG_MASK(3),
TRIGGER_TS_SORTER_MASK_NO_META_DATA = BIT_FLAG_MASK(4),
} ETriggerTimestampSorterMask;
typedef struct SSTriggerTimestampSorter {
struct SStreamTriggerTask *pTask;
int64_t flags; // bitmask of ETriggerTimestampSorterMask
STimeWindow readRange;
int64_t tbUid;
int32_t tsSlotId;
SArray *pMetaNodeBuf;
SArray *pMetaLists;
SMultiwayMergeTreeInfo *pDataMerger;
SArray *pSessWins;
} SSTriggerTimestampSorter;
#define SET_TRIGGER_TIMESTAMP_SORTER_EMPTY(pSorter) pSorter->readRange.skey = pSorter->readRange.ekey + 1
#define IS_TRIGGER_TIMESTAMP_SORTER_EMPTY(pSorter) (pSorter->readRange.skey > pSorter->readRange.ekey)
/**
* @brief Initializes a timestamp sorter for merging and sorting time-series data.
*
* @param pSorter The SSTriggerTimestampSorter instance to be initialized
* @param pTask The SStreamTriggerTask instance that contains the task information
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterInit(SSTriggerTimestampSorter *pSorter, struct SStreamTriggerTask *pTask);
/**
* @brief Destroys a timestamp sorter, releasing all allocated resources.
*
* @param ptr Pointer to the SSTriggerTimestampSorter instance to be destroyed
*/
void stTimestampSorterDestroy(void *ptr);
/**
* @brief Resets the timestamp sorter, clearing its state and preparing it for reuse.
*
* @param pSorter The SSTriggerTimestampSorter instance to be reset
*/
void stTimestampSorterReset(SSTriggerTimestampSorter *pSorter);
/**
* @brief Sets the sort information for the timestamp sorter, including table UID and timestamp slot ID.
*
* @param pSorter The SSTriggerTimestampSorter instance to set the sort info
* @param pRange The time range for sorting, containing start and end timestamps
* @param tbUid The UID of the table to be sorted
* @param tsSlotId The index of the timestamp column in the data block, starting from 0
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterSetSortInfo(SSTriggerTimestampSorter *pSorter, STimeWindow *pRange, int64_t tbUid,
int32_t tsSlotId);
/**
* @brief Sets metadata for data blocks in the timestamp sorter.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param pTableMeta metadatas of current table
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterSetMetaDatas(SSTriggerTimestampSorter *pSorter, SSTriggerTableMeta *pTableMeta);
/**
* @brief Sets the timestamp sorter without metadata; it would only be used to return bound data blocks.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterSetEmptyMetaDatas(SSTriggerTimestampSorter *pSorter);
/**
* @brief Get next data block from the sorter.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param ppDataBlock Pointer to store the current data block
* @param pStartIdx Pointer to store the start row index in the data block
* @param pEndIdx Pointer to store the end row index in the data block
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterNextDataBlock(SSTriggerTimestampSorter *pSorter, SSDataBlock **ppDataBlock, int32_t *pStartIdx,
int32_t *pEndIdx);
/**
* @brief Attempts to forward a specified number of rows on existing data blocks in pSorter.
* @note It always try to use nrows in metadata to accelerate the process.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param nrowsToSkip Number of rows to skip
* @param pSkipped Pointer to store the number of rows actually skipped, could be NULL if not needed
* @param pLastTs Pointer to store the last timestamp of the skipped rows, could be NULL if not needed
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterForwardNrows(SSTriggerTimestampSorter *pSorter, int64_t nrowsToSkip, int64_t *pSkipped,
int64_t *pLastTs);
/**
* @brief Attempts to forward as far as possible until time diff between two consecutive rows larger than gap.
* @note It always try to use skey/ekey in metadata to accelerate the process.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param ts The timestamp to start from
* @param gap The maximum allowed gap between consecutive timestamps
* @param pLastTs Pointer to store the last timestamp of the skipped rows, could be NULL if not needed
* @param pNextTs Pointer to store the next timestamp after the extended range, could be NULL if not needed
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterForwardTs(SSTriggerTimestampSorter *pSorter, int64_t ts, int64_t gap, int64_t *pLastTs,
int64_t *pNextTs);
/**
* @brief Get the metadata of the next data block to be fetched.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param ppMeta Pointer to store the metadata of the next data block to be fetched or NULL if no need to fetch more
* data blocks now
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterGetMetaToFetch(SSTriggerTimestampSorter *pSorter, SSTriggerMetaData **ppMeta);
/**
* @brief Binds a fetched data block to the sorter.
*
* @param pSorter The SSTriggerTimestampSorter instance responsible for merging
* @param pDataBlock Pointer to the data block to be bound, set to NULL if successfully bound
* @return int32_t Status code indicating success or error
*/
int32_t stTimestampSorterBindDataBlock(SSTriggerTimestampSorter *pSorter, SSDataBlock **ppDataBlock);
typedef struct SSTriggerColMatch {
union {
col_id_t otbColId;
col_id_t otbSlotId;
};
col_id_t vtbSlotId;
} SSTriggerColMatch;
typedef struct SSTriggerTableColRef {
int64_t otbSuid;
int64_t otbUid;
int32_t otbVgId;
SArray *pColMatches; // SArray<SSTriggerColMatch>
SArray *pNewColMatches; // SArray<SSTriggerColMatch>
} SSTriggerTableColRef;
typedef enum ETriggerVtableMergerMask {
TRIGGER_VTABLE_MERGER_MASK_MERGE_INFO_SET = BIT_FLAG_MASK(0),
TRIGGER_VTABLE_MERGER_MASK_META_DATA_SET = BIT_FLAG_MASK(1),
} ETriggerVtableMergerMask;
typedef struct SSTriggerVtableMerger {
struct SStreamTriggerTask *pTask;
int64_t flags; // bitmask of ETriggerVtableMergerMask
SSDataBlock *pDataBlock;
SFilterInfo *pFilter;
int32_t nVirDataCols; // number of non-pseudo data columns in pDataBlock
STimeWindow readRange;
SArray *pReaderInfos; // SArray<SVtableMergerReaderInfo>
SArray *pReaders; // SArray<SSTriggerTimestampSorter *>
SSDataBlock *pPseudoCols; // pseudo columns , could be NULL if no pseudo columns
SMultiwayMergeTreeInfo *pDataMerger;
} SSTriggerVtableMerger;
#define SET_TRIGGER_VTABLE_MERGER_EMPTY(pMerger) pMerger->readRange.skey = pMerger->readRange.ekey + 1
#define IS_TRIGGER_VTABLE_MERGER_EMPTY(pMerger) (pMerger->readRange.skey > pMerger->readRange.ekey)
/**
* @brief Initializes a vtable merger for merging data from original tables.
*
* @param pMerger The SSTriggerVtableMerger instance to be initialized
* @param pTask The SStreamTriggerTask instance that contains the task information
* @param ppDataBlock Pointer to the data block to store the merged data, each column's colid is incremental
* @param pFilter Pointer to the filter for the virtual table, can be NULL if no filter is present
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerInit(SSTriggerVtableMerger *pMerger, struct SStreamTriggerTask *pTask, SSDataBlock **ppDataBlock,
SFilterInfo **ppFilter, int32_t nVirDataCols);
/**
* @brief Destroys a vtable merger, releasing all allocated resources.
*
* @param ptr Pointer to the SSTriggerVtableMerger instance to be destroyed
*/
void stVtableMergerDestroy(void *ptr);
/**
* @brief Resets the vtable merger, clearing its state and preparing it for reuse.
*
* @param pMerger The SSTriggerVtableMerger instance to be reset
* @return int32_t Status code indicating success or error
*/
void stVtableMergerReset(SSTriggerVtableMerger *pMerger);
/**
* @brief Sets the merge information for the vtable merger, including timestamp slot ID, column maps, and filter.
*
* @param pMerger The SSTriggerVtableMerger instance to be configured
* @param pRange The time range for merging, containing start and end timestamps
* @param pTableColRefs Array of table column references, each containing original and virtual table column mappings
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerSetMergeInfo(SSTriggerVtableMerger *pMerger, STimeWindow *pRange, SArray *pTableColRefs);
int32_t stVtableMergerSetPseudoCols(SSTriggerVtableMerger *pMerger, SSDataBlock **ppDataBlock);
/**
* @brief Sets metadata for data blocks in the vtable merger.
*
* @param pMerger The SSTriggerVtableMerger instance responsible for merging
* @param pOrigTableMetas Hash<tbUid, SSTriggerTableMeta> metadatas of all original tables
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerSetMetaDatas(SSTriggerVtableMerger *pMerger, SSHashObj *pOrigTableMetas);
/**
* @brief Sets the underlying timestamp sorters without metadata.
*
* @param pMerger The SSTriggerVtableMerger instance responsible for merging
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerSetEmptyMetaDatas(SSTriggerVtableMerger *pMerger);
/**
* @brief Gets next data block from the vtable merger.
*
* @param pMerger The SSTriggerVtableMerger instance responsible for merging
* @param ppDataBlock Pointer to store the current data block
* @param pStartIdx Pointer to store the start row index in the data block
* @param pEndIdx Pointer to store the end row index in the data block
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerNextDataBlock(SSTriggerVtableMerger *pMerger, SSDataBlock **ppDataBlock);
/**
* @brief Gets the metadata for the data blocks to be fetched.
*
* @param pMerger The SSTriggerVtableMerger instance responsible for merging
* @param ppMeta Pointer to store the metadata of the next data block to be fetched or NULL if no need to fetch more
* data blocks now
* @param ppColRef Pointer to store the column reference for the next data block to be fetched
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerGetMetaToFetch(SSTriggerVtableMerger *pMerger, SSTriggerMetaData **ppMeta,
SSTriggerTableColRef **ppColRef);
/**
* @brief Binds a fetched data block to the vtable merger.
*
* @param pMerger The SSTriggerVtableMerger instance responsible for merging
* @param ppDataBlock Pointer to the data block to be bound, set to NULL if successfully bound
* @return int32_t Status code indicating success or error
*/
int32_t stVtableMergerBindDataBlock(SSTriggerVtableMerger *pMerger, SSDataBlock **ppDataBlock);
typedef struct SSTriggerDataSlice {
SSDataBlock *pDataBlock;
int32_t startIdx;
int32_t endIdx;
} SSTriggerDataSlice;
typedef struct SSTriggerNewTimestampSorter {
struct SStreamTriggerTask *pTask;
int32_t verColBias;
bool inUse;
SSDataBlock *pDataBlock;
int32_t tsSlotId;
SArray *pSliceBuf; // SArray<SNewTimestampSorterSlice>
SArray *pSliceLists; // SArray<SNewTimestampSorterSliceList>
SMultiwayMergeTreeInfo *pDataMerger;
} SSTriggerNewTimestampSorter;
/**
* @brief Initializes a timestamp sorter for sorting table data.
*
* @param pSorter The SSTriggerNewTimestampSorter instance to be initialized
* @param pTask The SStreamTriggerTask instance that contains the task information
* @param verColBias The bias to the version column index in the data block
* @return int32_t Status code indicating success or error
*/
int32_t stNewTimestampSorterInit(SSTriggerNewTimestampSorter *pSorter, struct SStreamTriggerTask *pTask,
int32_t verColBias);
/**
* @brief Destroys a timestamp sorter, releasing all allocated resources.
*
* @param ptr Pointer to the SSTriggerNewTimestampSorter instance to be destroyed
*/
void stNewTimestampSorterDestroy(void *ptr);
/**
* @brief Resets the timestamp sorter, clearing its state and preparing it for reuse.
*
* @param pSorter The SSTriggerNewTimestampSorter instance to be reset
*/
void stNewTimestampSorterReset(SSTriggerNewTimestampSorter *pSorter);
/**
* @brief Set the table data for the timestamp sorter
*
* @param pSorter The SSTriggerNewTimestampSorter instance to set the data
* @param tbUid The UID of the table to be sorted
* @param tsSlotId The index of the timestamp column in the data block, starting from 0
* @param pReadRange The time range for sorting, containing start and end timestamps
* @param pMetas The metadatas of current table
* @param pSlice The data slice containing the data block and the range of rows to be considered
* @return int32_t Status code indicating success or error
*/
int32_t stNewTimestampSorterSetData(SSTriggerNewTimestampSorter *pSorter, int64_t tbUid, int32_t tsSlotId,
STimeWindow *pReadRange, SObjList *pMetas, SSTriggerDataSlice *pSlice);
/**
* @brief Get next data block from the sorter.
*
* @param pSorter The SSTriggerNewTimestampSorter instance responsible for merging
* @param ppDataBlock Pointer to store the current data block
* @param pStartIdx Pointer to store the start row index in the data block
* @param pEndIdx Pointer to store the end row index in the data block
* @return int32_t Status code indicating success or error
*/
int32_t stNewTimestampSorterNextDataBlock(SSTriggerNewTimestampSorter *pSorter, SSDataBlock **ppDataBlock,
int32_t *pStartIdx, int32_t *pEndIdx);
typedef struct SSTriggerNewVtableMerger {
struct SStreamTriggerTask *pTask;
SSDataBlock *pDataBlock;
bool *pIsPseudoCol; // whether the column is pseudo column, could be NULL if no pseudo columns
SFilterInfo *pFilter;
bool inUse;
SSDataBlock *pPseudoColValues; // value of pseudo columns, could be NULL if no pseudo columns
int32_t tsSlotId;
int32_t nReaders;
SArray *pReaderInfos; // SArray<SNewVtableMergerReaderInfo>
SMultiwayMergeTreeInfo *pDataMerger;
} SSTriggerNewVtableMerger;
/**
* @brief Initializes a vtable merger for merging data from original tables.
*
* @param pMerger The SSTriggerNewVtableMerger instance to be initialized
* @param pTask The SStreamTriggerTask instance that contains the task information
* @param pDataBlock Pointer to the data block to store the merged data, each column's colid is incremental
* @param pIsPseudoCol Array indicating which columns are pseudo columns, can be NULL if no pseudo columns
* @param pFilter Pointer to the filter for the virtual table, can be NULL if no filter is present
* @return int32_t Status code indicating success or error
*/
int32_t stNewVtableMergerInit(SSTriggerNewVtableMerger *pMerger, struct SStreamTriggerTask *pTask,
SSDataBlock *pDataBlock, bool *pIsPseudoCol, SNode *pFilter);
bool stNewVtableMergerNeedPseudoCols(SSTriggerNewVtableMerger *pMerger);
/**
* @brief Destroys a vtable merger, releasing all allocated resources.
*
* @param ptr Pointer to the SSTriggerNewVtableMerger instance to be destroyed
*/
void stNewVtableMergerDestroy(void *ptr);
/**
* @brief Resets the vtable merger, clearing its state and preparing it for reuse.
*
* @param pMerger The SSTriggerNewVtableMerger instance to be reset
* @return int32_t Status code indicating success or error
*/
void stNewVtableMergerReset(SSTriggerNewVtableMerger *pMerger);
/**
* @brief Set the data for the vtable merger
*
* @param pMerger The SSTriggerNewVtableMerger instance responsible for merging
* @param vtbUid The UID of the virtual table
* @param tsSlotId The index of the timestamp column in the data block, starting from 0
* @param pReadRange The time range for sorting, containing start and end timestamps
* @param pTableUids List of original table UIDs involved in the merge
* @param pTableColRefs Array of table column references, each containing original and virtual table column mappings
* @param pMetas The metadatas of all original tables
* @param pSlices The hash map from original table uid to its data slice
* @return int32_t
*/
int32_t stNewVtableMergerSetData(SSTriggerNewVtableMerger *pMerger, int64_t vtbUid, int32_t tsSlotId,
STimeWindow *pReadRange, SObjList *pTableUids, SArray *pTableColRefs,
SSHashObj *pMetas, SSHashObj *pSlices);
/**
* @brief Gets next data block from the vtable merger.
*
* @param pMerger The SSTriggerNewVtableMerger instance responsible for merging
* @param ppDataBlock Pointer to store the current data block
* @param pStartIdx Pointer to store the start row index in the data block
* @param pEndIdx Pointer to store the end row index in the data block
* @return int32_t Status code indicating success or error
*/
int32_t stNewVtableMergerNextDataBlock(SSTriggerNewVtableMerger *pMerger, SSDataBlock **ppDataBlock, int32_t *pStartIdx,
int32_t *pEndIdx);
#ifdef __cplusplus
}
#endif
#endif // TDENGINE_STREAM_TRIGGER_MERGER_H