plannodes.h 10.1 KB
Newer Older
X
Xiaoyu Wang 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/*
 * 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 _TD_PLANN_NODES_H_
#define _TD_PLANN_NODES_H_

#ifdef __cplusplus
extern "C" {
#endif

X
Xiaoyu Wang 已提交
23
#include "query.h"
24
#include "querynodes.h"
X
Xiaoyu Wang 已提交
25
#include "tname.h"
X
Xiaoyu Wang 已提交
26 27

typedef struct SLogicNode {
28 29 30 31
  ENodeType          type;
  SNodeList*         pTargets;  // SColumnNode
  SNode*             pConditions;
  SNodeList*         pChildren;
X
Xiaoyu Wang 已提交
32
  struct SLogicNode* pParent;
33
  int32_t            optimizedFlag;
X
Xiaoyu Wang 已提交
34 35
} SLogicNode;

36
typedef enum EScanType { SCAN_TYPE_TAG = 1, SCAN_TYPE_TABLE, SCAN_TYPE_SYSTEM_TABLE, SCAN_TYPE_STREAM } EScanType;
X
Xiaoyu Wang 已提交
37

X
Xiaoyu Wang 已提交
38
typedef struct SScanLogicNode {
39 40 41
  SLogicNode         node;
  SNodeList*         pScanCols;
  SNodeList*         pScanPseudoCols;
X
Xiaoyu Wang 已提交
42
  struct STableMeta* pMeta;
43 44 45 46 47 48 49 50 51 52 53 54 55 56
  SVgroupsInfo*      pVgroupList;
  EScanType          scanType;
  uint8_t            scanSeq[2];  // first is scan count, and second is reverse scan count
  STimeWindow        scanRange;
  SName              tableName;
  bool               showRewrite;
  double             ratio;
  SNodeList*         pDynamicScanFuncs;
  int32_t            dataRequired;
  int64_t            interval;
  int64_t            offset;
  int64_t            sliding;
  int8_t             intervalUnit;
  int8_t             slidingUnit;
X
Xiaoyu Wang 已提交
57
  SNode*             pTagCond;
X
Xiaoyu Wang 已提交
58 59 60 61
} SScanLogicNode;

typedef struct SJoinLogicNode {
  SLogicNode node;
62 63
  EJoinType  joinType;
  SNode*     pOnConditions;
X
Xiaoyu Wang 已提交
64 65 66 67 68 69 70 71 72 73 74
} SJoinLogicNode;

typedef struct SAggLogicNode {
  SLogicNode node;
  SNodeList* pGroupKeys;
  SNodeList* pAggFuncs;
} SAggLogicNode;

typedef struct SProjectLogicNode {
  SLogicNode node;
  SNodeList* pProjections;
75 76 77 78 79
  char       stmtName[TSDB_TABLE_NAME_LEN];
  int64_t    limit;
  int64_t    offset;
  int64_t    slimit;
  int64_t    soffset;
X
Xiaoyu Wang 已提交
80 81
} SProjectLogicNode;

82
typedef struct SVnodeModifLogicNode {
83 84 85
  SLogicNode     node;
  int32_t        msgType;
  SArray*        pDataBlocks;
86 87 88
  SVgDataBlocks* pVgDataBlocks;
} SVnodeModifLogicNode;

X
Xiaoyu Wang 已提交
89 90
typedef struct SExchangeLogicNode {
  SLogicNode node;
91 92
  int32_t    srcGroupId;
  uint8_t    precision;
X
Xiaoyu Wang 已提交
93 94
} SExchangeLogicNode;

95
typedef enum EWindowType { WINDOW_TYPE_INTERVAL = 1, WINDOW_TYPE_SESSION, WINDOW_TYPE_STATE } EWindowType;
X
Xiaoyu Wang 已提交
96

X
Xiaoyu Wang 已提交
97
typedef struct SWindowLogicNode {
98
  SLogicNode  node;
X
Xiaoyu Wang 已提交
99
  EWindowType winType;
100 101 102 103 104 105 106 107 108 109 110
  SNodeList*  pFuncs;
  int64_t     interval;
  int64_t     offset;
  int64_t     sliding;
  int8_t      intervalUnit;
  int8_t      slidingUnit;
  int64_t     sessionGap;
  SNode*      pTspk;
  SNode*      pStateExpr;
  int8_t      triggerType;
  int64_t     watermark;
X
Xiaoyu Wang 已提交
111 112
} SWindowLogicNode;

X
Xiaoyu Wang 已提交
113
typedef struct SFillLogicNode {
X
Xiaoyu Wang 已提交
114 115 116 117 118
  SLogicNode  node;
  EFillMode   mode;
  SNode*      pWStartTs;
  SNode*      pValues;  // SNodeListNode
  STimeWindow timeRange;
X
Xiaoyu Wang 已提交
119 120
} SFillLogicNode;

X
Xiaoyu Wang 已提交
121 122 123 124 125
typedef struct SSortLogicNode {
  SLogicNode node;
  SNodeList* pSortKeys;
} SSortLogicNode;

126 127 128 129 130
typedef struct SPartitionLogicNode {
  SLogicNode node;
  SNodeList* pPartitionKeys;
} SPartitionLogicNode;

131 132 133 134 135 136 137
typedef enum ESubplanType {
  SUBPLAN_TYPE_MERGE = 1,
  SUBPLAN_TYPE_PARTIAL,
  SUBPLAN_TYPE_SCAN,
  SUBPLAN_TYPE_MODIFY
} ESubplanType;

X
Xiaoyu Wang 已提交
138 139
typedef struct SSubplanId {
  uint64_t queryId;
140 141
  int32_t  groupId;
  int32_t  subplanId;
X
Xiaoyu Wang 已提交
142 143
} SSubplanId;

X
Xiaoyu Wang 已提交
144
typedef struct SLogicSubplan {
145 146 147 148 149 150
  ENodeType     type;
  SSubplanId    id;
  SNodeList*    pChildren;
  SNodeList*    pParents;
  SLogicNode*   pNode;
  ESubplanType  subplanType;
X
Xiaoyu Wang 已提交
151
  SVgroupsInfo* pVgroupList;
152 153
  int32_t       level;
  int32_t       splitFlag;
X
Xiaoyu Wang 已提交
154
} SLogicSubplan;
X
Xiaoyu Wang 已提交
155 156

typedef struct SQueryLogicPlan {
157
  ENodeType  type;
X
Xiaoyu Wang 已提交
158
  SNodeList* pTopSubplans;
X
Xiaoyu Wang 已提交
159 160
} SQueryLogicPlan;

X
Xiaoyu Wang 已提交
161 162
typedef struct SSlotDescNode {
  ENodeType type;
163
  int16_t   slotId;
X
Xiaoyu Wang 已提交
164
  SDataType dataType;
165 166 167
  bool      reserve;
  bool      output;
  bool      tag;
X
Xiaoyu Wang 已提交
168 169
} SSlotDescNode;

X
Xiaoyu Wang 已提交
170
typedef struct SDataBlockDescNode {
171 172
  ENodeType  type;
  int16_t    dataBlockId;
X
Xiaoyu Wang 已提交
173
  SNodeList* pSlots;
174 175 176
  int32_t    totalRowSize;
  int32_t    outputRowSize;
  uint8_t    precision;
X
Xiaoyu Wang 已提交
177
} SDataBlockDescNode;
X
Xiaoyu Wang 已提交
178 179

typedef struct SPhysiNode {
180
  ENodeType           type;
X
Xiaoyu Wang 已提交
181
  SDataBlockDescNode* pOutputDataBlockDesc;
182 183 184
  SNode*              pConditions;
  SNodeList*          pChildren;
  struct SPhysiNode*  pParent;
X
Xiaoyu Wang 已提交
185 186 187
} SPhysiNode;

typedef struct SScanPhysiNode {
X
Xiaoyu Wang 已提交
188
  SPhysiNode node;
X
Xiaoyu Wang 已提交
189
  SNodeList* pScanCols;
190 191 192 193
  SNodeList* pScanPseudoCols;
  uint64_t   uid;  // unique id of the table
  int8_t     tableType;
  SName      tableName;
X
Xiaoyu Wang 已提交
194 195 196 197
} SScanPhysiNode;

typedef SScanPhysiNode STagScanPhysiNode;

X
Xiaoyu Wang 已提交
198 199
typedef struct SSystemTableScanPhysiNode {
  SScanPhysiNode scan;
200 201 202
  SEpSet         mgmtEpSet;
  bool           showRewrite;
  int32_t        accountId;
X
Xiaoyu Wang 已提交
203 204
} SSystemTableScanPhysiNode;

X
Xiaoyu Wang 已提交
205 206
typedef struct STableScanPhysiNode {
  SScanPhysiNode scan;
207 208 209 210 211 212 213 214 215 216
  uint8_t        scanSeq[2];  // first is scan count, and second is reverse scan count
  STimeWindow    scanRange;
  double         ratio;
  int32_t        dataRequired;
  SNodeList*     pDynamicScanFuncs;
  int64_t        interval;
  int64_t        offset;
  int64_t        sliding;
  int8_t         intervalUnit;
  int8_t         slidingUnit;
X
Xiaoyu Wang 已提交
217 218 219
} STableScanPhysiNode;

typedef STableScanPhysiNode STableSeqScanPhysiNode;
5
54liuyao 已提交
220
typedef STableScanPhysiNode SStreamScanPhysiNode;
X
Xiaoyu Wang 已提交
221 222 223 224

typedef struct SProjectPhysiNode {
  SPhysiNode node;
  SNodeList* pProjections;
225 226 227 228
  int64_t    limit;
  int64_t    offset;
  int64_t    slimit;
  int64_t    soffset;
X
Xiaoyu Wang 已提交
229 230
} SProjectPhysiNode;

X
Xiaoyu Wang 已提交
231 232
typedef struct SJoinPhysiNode {
  SPhysiNode node;
233
  EJoinType  joinType;
X
Xiaoyu Wang 已提交
234
  SNode*     pOnConditions;
X
Xiaoyu Wang 已提交
235 236 237
  SNodeList* pTargets;
} SJoinPhysiNode;

X
Xiaoyu Wang 已提交
238 239
typedef SJoinPhysiNode SSortMergeJoinPhysiNode;

X
Xiaoyu Wang 已提交
240 241
typedef struct SAggPhysiNode {
  SPhysiNode node;
242
  SNodeList* pExprs;  // these are expression list of group_by_clause and parameter expression of aggregate function
X
Xiaoyu Wang 已提交
243
  SNodeList* pGroupKeys;
X
Xiaoyu Wang 已提交
244 245 246
  SNodeList* pAggFuncs;
} SAggPhysiNode;

X
Xiaoyu Wang 已提交
247
typedef struct SDownstreamSourceNode {
248
  ENodeType      type;
X
Xiaoyu Wang 已提交
249
  SQueryNodeAddr addr;
250 251
  uint64_t       taskId;
  uint64_t       schedId;
X
Xiaoyu Wang 已提交
252
} SDownstreamSourceNode;
X
Xiaoyu Wang 已提交
253 254

typedef struct SExchangePhysiNode {
X
Xiaoyu Wang 已提交
255
  SPhysiNode node;
256
  int32_t    srcGroupId;     // group id of datasource suplans
X
Xiaoyu Wang 已提交
257
  SNodeList* pSrcEndPoints;  // element is SDownstreamSource, scheduler fill by calling qSetSuplanExecutionNode
X
Xiaoyu Wang 已提交
258 259
} SExchangePhysiNode;

X
Xiaoyu Wang 已提交
260
typedef struct SWinodwPhysiNode {
X
Xiaoyu Wang 已提交
261
  SPhysiNode node;
262
  SNodeList* pExprs;  // these are expression list of parameter expression of function
X
Xiaoyu Wang 已提交
263
  SNodeList* pFuncs;
264 265 266
  SNode*     pTspk;  // timestamp primary key
  int8_t     triggerType;
  int64_t    watermark;
X
Xiaoyu Wang 已提交
267 268 269 270
} SWinodwPhysiNode;

typedef struct SIntervalPhysiNode {
  SWinodwPhysiNode window;
271 272 273 274 275
  int64_t          interval;
  int64_t          offset;
  int64_t          sliding;
  int8_t           intervalUnit;
  int8_t           slidingUnit;
X
Xiaoyu Wang 已提交
276 277
} SIntervalPhysiNode;

X
Xiaoyu Wang 已提交
278 279
typedef SIntervalPhysiNode SStreamIntervalPhysiNode;

X
Xiaoyu Wang 已提交
280
typedef struct SFillPhysiNode {
X
Xiaoyu Wang 已提交
281 282 283 284 285 286
  SPhysiNode  node;
  EFillMode   mode;
  SNode*      pWStartTs;  // SColumnNode
  SNode*      pValues;    // SNodeListNode
  SNodeList*  pTargets;
  STimeWindow timeRange;
X
Xiaoyu Wang 已提交
287 288
} SFillPhysiNode;

289 290
typedef struct SMultiTableIntervalPhysiNode {
  SIntervalPhysiNode interval;
291
  SNodeList*         pPartitionKeys;
292 293
} SMultiTableIntervalPhysiNode;

X
Xiaoyu Wang 已提交
294 295
typedef struct SSessionWinodwPhysiNode {
  SWinodwPhysiNode window;
296
  int64_t          gap;
X
Xiaoyu Wang 已提交
297 298
} SSessionWinodwPhysiNode;

5
54liuyao 已提交
299 300
typedef SSessionWinodwPhysiNode SStreamSessionWinodwPhysiNode;

301 302
typedef struct SStateWinodwPhysiNode {
  SWinodwPhysiNode window;
303
  SNode*           pStateKey;
304 305
} SStateWinodwPhysiNode;

X
Xiaoyu Wang 已提交
306 307
typedef struct SSortPhysiNode {
  SPhysiNode node;
308 309
  SNodeList* pExprs;     // these are expression list of order_by_clause and parameter expression of aggregate function
  SNodeList* pSortKeys;  // element is SOrderByExprNode, and SOrderByExprNode::pExpr is SColumnNode
X
Xiaoyu Wang 已提交
310
  SNodeList* pTargets;
X
Xiaoyu Wang 已提交
311 312
} SSortPhysiNode;

313 314
typedef struct SPartitionPhysiNode {
  SPhysiNode node;
315
  SNodeList* pExprs;  // these are expression list of partition_by_clause
316
  SNodeList* pPartitionKeys;
X
Xiaoyu Wang 已提交
317
  SNodeList* pTargets;
318 319
} SPartitionPhysiNode;

X
Xiaoyu Wang 已提交
320
typedef struct SDataSinkNode {
321
  ENodeType           type;
X
Xiaoyu Wang 已提交
322
  SDataBlockDescNode* pInputDataBlockDesc;
X
Xiaoyu Wang 已提交
323 324 325 326 327 328 329 330
} SDataSinkNode;

typedef struct SDataDispatcherNode {
  SDataSinkNode sink;
} SDataDispatcherNode;

typedef struct SDataInserterNode {
  SDataSinkNode sink;
331 332 333
  int32_t       numOfTables;
  uint32_t      size;
  char*         pData;
X
Xiaoyu Wang 已提交
334 335
} SDataInserterNode;

X
Xiaoyu Wang 已提交
336
typedef struct SSubplan {
337 338 339 340 341 342 343 344 345 346 347 348
  ENodeType      type;
  SSubplanId     id;  // unique id of the subplan
  ESubplanType   subplanType;
  int32_t        msgType;  // message type for subplan, used to denote the send message type to vnode.
  int32_t        level;    // the execution level of current subplan, starting from 0 in a top-down manner.
  char           dbFName[TSDB_DB_FNAME_LEN];
  SQueryNodeAddr execNode;      // for the scan/modify subplan, the optional execution node
  SQueryNodeStat execNodeStat;  // only for scan subplan
  SNodeList*     pChildren;     // the datasource subplan,from which to fetch the result
  SNodeList*     pParents;      // the data destination subplan, get data from current subplan
  SPhysiNode*    pNode;         // physical plan of current subplan
  SDataSinkNode* pDataSink;     // data of the subplan flow into the datasink
X
Xiaoyu Wang 已提交
349
  SNode*         pTagCond;
X
Xiaoyu Wang 已提交
350 351
} SSubplan;

352
typedef enum EExplainMode { EXPLAIN_MODE_DISABLE = 1, EXPLAIN_MODE_STATIC, EXPLAIN_MODE_ANALYZE } EExplainMode;
353 354 355

typedef struct SExplainInfo {
  EExplainMode mode;
356 357
  bool         verbose;
  double       ratio;
358
} SExplainInfo;
359

X
Xiaoyu Wang 已提交
360
typedef struct SQueryPlan {
361 362 363 364
  ENodeType    type;
  uint64_t     queryId;
  int32_t      numOfSubplans;
  SNodeList*   pSubplans;  // Element is SNodeListNode. The execution level of subplan, starting from 0.
365
  SExplainInfo explainInfo;
X
Xiaoyu Wang 已提交
366
  SArray*      pPlaceholderValues;
X
Xiaoyu Wang 已提交
367 368
} SQueryPlan;

369 370
void nodesWalkPhysiPlan(SNode* pNode, FNodeWalker walker, void* pContext);

X
Xiaoyu Wang 已提交
371 372 373 374 375
#ifdef __cplusplus
}
#endif

#endif /*_TD_PLANN_NODES_H_*/