plannerInt.h 4.3 KB
Newer Older
H
Hongze Cheng 已提交
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_PLANNER_INT_H_
#define _TD_PLANNER_INT_H_

#ifdef __cplusplus
extern "C" {
#endif

23 24 25
#include "common.h"
#include "tarray.h"
#include "planner.h"
H
Haojun Liao 已提交
26
#include "taosmsg.h"
27 28

typedef struct SQueryNodeBasicInfo {
29 30
  int32_t   type;          // operator type
  char     *name;          // operator name
31 32
} SQueryNodeBasicInfo;

33 34 35 36 37 38 39 40
typedef struct SQueryDistPlanNodeInfo {
  bool      stableQuery;   // super table query or not
  int32_t   phase;         // merge|partial
  int32_t   type;          // operator type
  char     *name;          // operator name
  SEpSet   *sourceEp;      // data source epset
} SQueryDistPlanNodeInfo;

41
typedef struct SQueryTableInfo {
42 43 44
  char       *tableName;
  uint64_t    uid;
  STimeWindow window;
45 46
} SQueryTableInfo;

47
typedef struct SQueryPlanNode {
48 49 50
  SQueryNodeBasicInfo info;
  SSchema            *pSchema;      // the schema of the input SSDatablock
  int32_t             numOfCols;    // number of input columns
51
  SArray             *pExpr;        // the query functions or sql aggregations
52
  int32_t             numOfExpr;  // number of result columns, which is also the number of pExprs
53 54 55 56
  void               *pExtInfo;     // additional information
  // previous operator to generated result for current node to process
  // in case of join, multiple prev nodes exist.
  SArray             *pPrevNodes;   // upstream nodes
57 58
  struct SQueryPlanNode  *nextNode;
} SQueryPlanNode;
59

60 61 62 63 64
typedef struct SDataBlockSchema {
  int32_t             index;
  SSchema            *pSchema;      // the schema of the SSDatablock
  int32_t             numOfCols;    // number of columns
} SDataBlockSchema;
65

66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
typedef struct SQueryPhyPlanNode {
  SQueryNodeBasicInfo info;
  SArray             *pTarget;      // target list to be computed at this node
  SArray             *qual;         // implicitly-ANDed qual conditions
  SDataBlockSchema    targetSchema;
  // children plan to generated result for current node to process
  // in case of join, multiple plan nodes exist.
  SArray             *pChildren;
} SQueryPhyPlanNode;

typedef struct SQueryScanPhyNode {
  SQueryPhyPlanNode node;
  uint64_t          uid;
} SQueryScanPhyNode;

typedef struct SQueryProjectPhyNode {
  SQueryPhyPlanNode node;
} SQueryProjectPhyNode;

typedef struct SQueryAggPhyNode {
  SQueryPhyPlanNode node;
  SArray           *pGroup;
  // SInterval
} SQueryAggPhyNode;

typedef struct SQueryProfileSummary {
92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
  int64_t startTs;      // Object created and added into the message queue
  int64_t endTs;        // the timestamp when the task is completed
  int64_t cputime;      // total cpu cost, not execute elapsed time

  int64_t loadRemoteDataDuration;       // remote io time
  int64_t loadNativeDataDuration;       // native disk io time

  uint64_t loadNativeData; // blocks + SMA + header files
  uint64_t loadRemoteData; // remote data acquired by exchange operator.

  uint64_t waitDuration; // the time to waiting to be scheduled in queue does matter, so we need to record it
  int64_t  addQTs;       // the time to be added into the message queue, used to calculate the waiting duration in queue.

  uint64_t totalRows;
  uint64_t loadRows;
  uint32_t totalBlocks;
  uint32_t loadBlocks;
  uint32_t loadBlockAgg;
  uint32_t skipBlocks;
  uint64_t resultSize;   // generated result size in Kb.
112
} SQueryProfileSummary;
113 114 115 116

typedef struct SQueryTask {
  uint64_t            queryId; // query id
  uint64_t            taskId;  // task id
117
  SQueryPhyPlanNode *pNode;   // operator tree
118
  uint64_t            status;  // task status
119
  SQueryProfileSummary summary; // task execution summary
120 121 122
  void               *pOutputHandle; // result buffer handle, to temporarily keep the output result for next stage
} SQueryTask;

H
Hongze Cheng 已提交
123 124 125 126 127
#ifdef __cplusplus
}
#endif

#endif /*_TD_PLANNER_INT_H_*/