parAstCreater.c 57.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16

/*
 * 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/>.
 */

17 18
#include <regex.h>

X
Xiaoyu Wang 已提交
19 20
#include "parAst.h"
#include "parUtil.h"
X
Xiaoyu Wang 已提交
21
#include "ttime.h"
22

X
Xiaoyu Wang 已提交
23 24 25
#define CHECK_OUT_OF_MEM(p)                                                      \
  do {                                                                           \
    if (NULL == (p)) {                                                           \
26
      pCxt->errCode = TSDB_CODE_OUT_OF_MEMORY;                                   \
X
Xiaoyu Wang 已提交
27
      snprintf(pCxt->pQueryCxt->pMsg, pCxt->pQueryCxt->msgLen, "Out of memory"); \
X
Xiaoyu Wang 已提交
28 29
      return NULL;                                                               \
    }                                                                            \
30 31
  } while (0)

X
Xiaoyu Wang 已提交
32 33 34 35 36
#define CHECK_PARSER_STATUS(pCxt)             \
  do {                                        \
    if (TSDB_CODE_SUCCESS != pCxt->errCode) { \
      return NULL;                            \
    }                                         \
37 38
  } while (0)

39 40 41 42 43 44 45 46
#define COPY_STRING_FORM_ID_TOKEN(buf, pToken) strncpy(buf, (pToken)->z, TMIN((pToken)->n, sizeof(buf) - 1))
#define COPY_STRING_FORM_STR_TOKEN(buf, pToken)                              \
  do {                                                                       \
    if ((pToken)->n > 2) {                                                   \
      strncpy(buf, (pToken)->z + 1, TMIN((pToken)->n - 2, sizeof(buf) - 1)); \
    }                                                                        \
  } while (0)

X
Xiaoyu Wang 已提交
47
SToken nil_token = {.type = TK_NK_NIL, .n = 0, .z = NULL};
48

49
void initAstCreateContext(SParseContext* pParseCxt, SAstCreateContext* pCxt) {
50
  memset(pCxt, 0, sizeof(SAstCreateContext));
51
  pCxt->pQueryCxt = pParseCxt;
52 53
  pCxt->msgBuf.buf = pParseCxt->pMsg;
  pCxt->msgBuf.len = pParseCxt->msgLen;
54 55
  pCxt->notSupport = false;
  pCxt->pRootNode = NULL;
D
dapan1121 已提交
56
  pCxt->placeholderNo = 0;
X
Xiaoyu Wang 已提交
57
  pCxt->pPlaceholderValues = NULL;
58
  pCxt->errCode = TSDB_CODE_SUCCESS;
59 60
}

X
Xiaoyu Wang 已提交
61
static void trimEscape(SToken* pName) {
62
  // todo need to deal with `ioo``ii` -> ioo`ii
X
Xiaoyu Wang 已提交
63 64 65 66 67 68 69
  if (NULL != pName && pName->n > 1 && '`' == pName->z[0]) {
    pName->z += 1;
    pName->n -= 2;
  }
}

static bool checkUserName(SAstCreateContext* pCxt, SToken* pUserName) {
70
  if (NULL == pUserName) {
71
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
72 73
  } else {
    if (pUserName->n >= TSDB_USER_LEN) {
74
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_NAME_OR_PASSWD_TOO_LONG);
X
Xiaoyu Wang 已提交
75
    }
76
  }
77
  if (TSDB_CODE_SUCCESS == pCxt->errCode) {
X
Xiaoyu Wang 已提交
78 79
    trimEscape(pUserName);
  }
80
  return TSDB_CODE_SUCCESS == pCxt->errCode;
81 82
}

83 84 85 86 87 88 89 90 91 92 93 94 95
static bool invalidPassword(const char* pPassword) {
  regex_t regex;

  if (regcomp(&regex, "[ '\"`\\]", REG_EXTENDED | REG_ICASE) != 0) {
    return false;
  }

  /* Execute regular expression */
  int32_t res = regexec(&regex, pPassword, 0, NULL, 0);
  regfree(&regex);
  return 0 == res;
}

96 97
static bool checkPassword(SAstCreateContext* pCxt, const SToken* pPasswordToken, char* pPassword) {
  if (NULL == pPasswordToken) {
98
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
99
  } else if (pPasswordToken->n >= (TSDB_USET_PASSWORD_LEN + 2)) {
100
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_NAME_OR_PASSWD_TOO_LONG);
X
Xiaoyu Wang 已提交
101
  } else {
102
    COPY_STRING_FORM_ID_TOKEN(pPassword, pPasswordToken);
X
Xiaoyu Wang 已提交
103 104
    strdequote(pPassword);
    if (strtrim(pPassword) <= 0) {
105
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_PASSWD_EMPTY);
106 107
    } else if (invalidPassword(pPassword)) {
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_PASSWD);
X
Xiaoyu Wang 已提交
108
    }
109
  }
110
  return TSDB_CODE_SUCCESS == pCxt->errCode;
111 112 113 114
}

static bool checkAndSplitEndpoint(SAstCreateContext* pCxt, const SToken* pEp, char* pFqdn, int32_t* pPort) {
  if (NULL == pEp) {
115
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
116
  } else if (pEp->n >= TSDB_FQDN_LEN + 2 + 6) {  // format 'fqdn:port'
117
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_NAME_OR_PASSWD_TOO_LONG);
X
Xiaoyu Wang 已提交
118
  } else {
119 120
    char ep[TSDB_FQDN_LEN + 6];
    COPY_STRING_FORM_STR_TOKEN(ep, pEp);
X
Xiaoyu Wang 已提交
121 122 123 124
    strdequote(ep);
    strtrim(ep);
    char* pColon = strchr(ep, ':');
    if (NULL == pColon) {
125
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_ENDPOINT);
X
Xiaoyu Wang 已提交
126 127
    } else {
      strncpy(pFqdn, ep, pColon - ep);
wafwerar's avatar
wafwerar 已提交
128
      *pPort = taosStr2Int32(pColon + 1, NULL, 10);
X
Xiaoyu Wang 已提交
129
      if (*pPort >= UINT16_MAX || *pPort <= 0) {
130
        pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_PORT);
X
Xiaoyu Wang 已提交
131 132
      }
    }
133
  }
134
  return TSDB_CODE_SUCCESS == pCxt->errCode;
135 136 137 138
}

static bool checkFqdn(SAstCreateContext* pCxt, const SToken* pFqdn) {
  if (NULL == pFqdn) {
139
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
140 141
  } else {
    if (pFqdn->n >= TSDB_FQDN_LEN) {
142
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_NAME_OR_PASSWD_TOO_LONG);
X
Xiaoyu Wang 已提交
143
    }
144
  }
145
  return TSDB_CODE_SUCCESS == pCxt->errCode;
146 147 148 149
}

static bool checkPort(SAstCreateContext* pCxt, const SToken* pPortToken, int32_t* pPort) {
  if (NULL == pPortToken) {
150
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
151
  } else {
wafwerar's avatar
wafwerar 已提交
152
    *pPort = taosStr2Int32(pPortToken->z, NULL, 10);
X
Xiaoyu Wang 已提交
153
    if (*pPort >= UINT16_MAX || *pPort <= 0) {
154
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_PORT);
X
Xiaoyu Wang 已提交
155
    }
156
  }
157
  return TSDB_CODE_SUCCESS == pCxt->errCode;
158 159
}

160
static bool checkDbName(SAstCreateContext* pCxt, SToken* pDbName, bool demandDb) {
161
  if (NULL == pDbName) {
162
    if (demandDb && NULL == pCxt->pQueryCxt->db) {
163
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_DB_NOT_SPECIFIED);
X
bugfix  
Xiaoyu Wang 已提交
164
    }
X
Xiaoyu Wang 已提交
165
  } else {
X
Xiaoyu Wang 已提交
166
    trimEscape(pDbName);
X
Xiaoyu Wang 已提交
167
    if (pDbName->n >= TSDB_DB_NAME_LEN) {
168
      pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_IDENTIFIER_NAME, pDbName->z);
X
Xiaoyu Wang 已提交
169 170
    }
  }
171
  return TSDB_CODE_SUCCESS == pCxt->errCode;
172
}
173

X
Xiaoyu Wang 已提交
174
static bool checkTableName(SAstCreateContext* pCxt, SToken* pTableName) {
X
Xiaoyu Wang 已提交
175
  trimEscape(pTableName);
X
Xiaoyu Wang 已提交
176
  if (NULL != pTableName && pTableName->n >= TSDB_TABLE_NAME_LEN) {
177
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_IDENTIFIER_NAME, pTableName->z);
X
Xiaoyu Wang 已提交
178
    return false;
179
  }
X
Xiaoyu Wang 已提交
180
  return true;
181 182
}

X
Xiaoyu Wang 已提交
183
static bool checkColumnName(SAstCreateContext* pCxt, SToken* pColumnName) {
X
Xiaoyu Wang 已提交
184
  trimEscape(pColumnName);
X
Xiaoyu Wang 已提交
185
  if (NULL != pColumnName && pColumnName->n >= TSDB_COL_NAME_LEN) {
186
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_IDENTIFIER_NAME, pColumnName->z);
X
Xiaoyu Wang 已提交
187
    return false;
188
  }
X
Xiaoyu Wang 已提交
189
  return true;
190 191
}

X
Xiaoyu Wang 已提交
192
static bool checkIndexName(SAstCreateContext* pCxt, SToken* pIndexName) {
X
Xiaoyu Wang 已提交
193
  trimEscape(pIndexName);
X
Xiaoyu Wang 已提交
194
  if (NULL != pIndexName && pIndexName->n >= TSDB_INDEX_NAME_LEN) {
195
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_IDENTIFIER_NAME, pIndexName->z);
X
Xiaoyu Wang 已提交
196
    return false;
X
Xiaoyu Wang 已提交
197
  }
X
Xiaoyu Wang 已提交
198
  return true;
X
Xiaoyu Wang 已提交
199 200
}

201 202 203 204 205 206 207 208 209
static bool checkComment(SAstCreateContext* pCxt, const SToken* pCommentToken, bool demand) {
  if (NULL == pCommentToken) {
    pCxt->errCode = demand ? TSDB_CODE_PAR_SYNTAX_ERROR : TSDB_CODE_SUCCESS;
  } else if (pCommentToken->n >= (TSDB_TB_COMMENT_LEN + 2)) {
    pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_COMMENT_TOO_LONG);
  }
  return TSDB_CODE_SUCCESS == pCxt->errCode;
}

210
SNode* createRawExprNode(SAstCreateContext* pCxt, const SToken* pToken, SNode* pNode) {
X
Xiaoyu Wang 已提交
211
  CHECK_PARSER_STATUS(pCxt);
212 213 214 215 216 217 218 219 220
  SRawExprNode* target = (SRawExprNode*)nodesMakeNode(QUERY_NODE_RAW_EXPR);
  CHECK_OUT_OF_MEM(target);
  target->p = pToken->z;
  target->n = pToken->n;
  target->pNode = pNode;
  return (SNode*)target;
}

SNode* createRawExprNodeExt(SAstCreateContext* pCxt, const SToken* pStart, const SToken* pEnd, SNode* pNode) {
X
Xiaoyu Wang 已提交
221
  CHECK_PARSER_STATUS(pCxt);
222 223 224 225 226 227 228 229 230
  SRawExprNode* target = (SRawExprNode*)nodesMakeNode(QUERY_NODE_RAW_EXPR);
  CHECK_OUT_OF_MEM(target);
  target->p = pStart->z;
  target->n = (pEnd->z + pEnd->n) - pStart->z;
  target->pNode = pNode;
  return (SNode*)target;
}

SNode* releaseRawExprNode(SAstCreateContext* pCxt, SNode* pNode) {
X
Xiaoyu Wang 已提交
231
  CHECK_PARSER_STATUS(pCxt);
232
  SRawExprNode* pRawExpr = (SRawExprNode*)pNode;
X
Xiaoyu Wang 已提交
233
  SNode*        pExpr = pRawExpr->pNode;
D
dapan1121 已提交
234
  if (nodesIsExprNode(pExpr)) {
X
Xiaoyu Wang 已提交
235 236 237 238 239 240 241
    if (QUERY_NODE_COLUMN == nodeType(pExpr)) {
      strcpy(((SExprNode*)pExpr)->aliasName, ((SColumnNode*)pExpr)->colName);
    } else {
      int32_t len = TMIN(sizeof(((SExprNode*)pExpr)->aliasName) - 1, pRawExpr->n);
      strncpy(((SExprNode*)pExpr)->aliasName, pRawExpr->p, len);
      ((SExprNode*)pExpr)->aliasName[len] = '\0';
    }
D
dapan1121 已提交
242
  }
wafwerar's avatar
wafwerar 已提交
243
  taosMemoryFreeClear(pNode);
244
  return pExpr;
245 246 247
}

SToken getTokenFromRawExprNode(SAstCreateContext* pCxt, SNode* pNode) {
X
Xiaoyu Wang 已提交
248
  if (NULL == pNode || QUERY_NODE_RAW_EXPR != nodeType(pNode)) {
249
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
250 251
    return nil_token;
  }
252
  SRawExprNode* target = (SRawExprNode*)pNode;
X
Xiaoyu Wang 已提交
253
  SToken        t = {.type = 0, .z = target->p, .n = target->n};
254 255 256
  return t;
}

257
SNodeList* createNodeList(SAstCreateContext* pCxt, SNode* pNode) {
X
Xiaoyu Wang 已提交
258
  CHECK_PARSER_STATUS(pCxt);
259 260
  SNodeList* list = nodesMakeList();
  CHECK_OUT_OF_MEM(list);
261
  pCxt->errCode = nodesListAppend(list, pNode);
X
Xiaoyu Wang 已提交
262
  return list;
263 264 265
}

SNodeList* addNodeToList(SAstCreateContext* pCxt, SNodeList* pList, SNode* pNode) {
X
Xiaoyu Wang 已提交
266
  CHECK_PARSER_STATUS(pCxt);
267
  pCxt->errCode = nodesListAppend(pList, pNode);
X
Xiaoyu Wang 已提交
268
  return pList;
269 270
}

X
Xiaoyu Wang 已提交
271
SNode* createColumnNode(SAstCreateContext* pCxt, SToken* pTableAlias, SToken* pColumnName) {
X
Xiaoyu Wang 已提交
272
  CHECK_PARSER_STATUS(pCxt);
273
  if (!checkTableName(pCxt, pTableAlias) || !checkColumnName(pCxt, pColumnName)) {
274 275 276 277
    return NULL;
  }
  SColumnNode* col = (SColumnNode*)nodesMakeNode(QUERY_NODE_COLUMN);
  CHECK_OUT_OF_MEM(col);
278
  if (NULL != pTableAlias) {
279
    COPY_STRING_FORM_ID_TOKEN(col->tableAlias, pTableAlias);
280
  }
281
  COPY_STRING_FORM_ID_TOKEN(col->colName, pColumnName);
282
  return (SNode*)col;
283
}
284

285
SNode* createValueNode(SAstCreateContext* pCxt, int32_t dataType, const SToken* pLiteral) {
X
Xiaoyu Wang 已提交
286
  CHECK_PARSER_STATUS(pCxt);
287 288
  SValueNode* val = (SValueNode*)nodesMakeNode(QUERY_NODE_VALUE);
  CHECK_OUT_OF_MEM(val);
289 290 291 292
  val->literal = strndup(pLiteral->z, pLiteral->n);
  if (TK_NK_ID != pLiteral->type && TK_TIMEZONE != pLiteral->type &&
      (IS_VAR_DATA_TYPE(dataType) || TSDB_DATA_TYPE_TIMESTAMP == dataType)) {
    trimString(pLiteral->z, pLiteral->n, val->literal, pLiteral->n);
X
Xiaoyu Wang 已提交
293
  }
294
  CHECK_OUT_OF_MEM(val->literal);
295
  val->node.resType.type = dataType;
X
Xiaoyu Wang 已提交
296
  val->node.resType.bytes = IS_VAR_DATA_TYPE(dataType) ? strlen(val->literal) : tDataTypes[dataType].bytes;
297 298 299
  if (TSDB_DATA_TYPE_TIMESTAMP == dataType) {
    val->node.resType.precision = TSDB_TIME_PRECISION_MILLI;
  }
300 301
  val->isDuration = false;
  val->translate = false;
302 303 304 305
  return (SNode*)val;
}

SNode* createDurationValueNode(SAstCreateContext* pCxt, const SToken* pLiteral) {
X
Xiaoyu Wang 已提交
306
  CHECK_PARSER_STATUS(pCxt);
307 308
  SValueNode* val = (SValueNode*)nodesMakeNode(QUERY_NODE_VALUE);
  CHECK_OUT_OF_MEM(val);
309 310 311
  val->literal = strndup(pLiteral->z, pLiteral->n);
  CHECK_OUT_OF_MEM(val->literal);
  val->isDuration = true;
312
  val->translate = false;
313 314 315
  val->node.resType.type = TSDB_DATA_TYPE_BIGINT;
  val->node.resType.bytes = tDataTypes[TSDB_DATA_TYPE_BIGINT].bytes;
  val->node.resType.precision = TSDB_TIME_PRECISION_MILLI;
316
  return (SNode*)val;
317 318
}

X
Xiaoyu Wang 已提交
319
SNode* createDefaultDatabaseCondValue(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
320
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
321 322 323 324
  if (NULL == pCxt->pQueryCxt->db) {
    return NULL;
  }

X
Xiaoyu Wang 已提交
325 326 327 328 329 330 331 332 333 334 335 336
  SValueNode* val = (SValueNode*)nodesMakeNode(QUERY_NODE_VALUE);
  CHECK_OUT_OF_MEM(val);
  val->literal = strdup(pCxt->pQueryCxt->db);
  CHECK_OUT_OF_MEM(val->literal);
  val->isDuration = false;
  val->translate = false;
  val->node.resType.type = TSDB_DATA_TYPE_BINARY;
  val->node.resType.bytes = strlen(val->literal);
  val->node.resType.precision = TSDB_TIME_PRECISION_MILLI;
  return (SNode*)val;
}

337
SNode* createPlaceholderValueNode(SAstCreateContext* pCxt, const SToken* pLiteral) {
X
Xiaoyu Wang 已提交
338
  CHECK_PARSER_STATUS(pCxt);
339 340
  SValueNode* val = (SValueNode*)nodesMakeNode(QUERY_NODE_VALUE);
  CHECK_OUT_OF_MEM(val);
341 342
  val->literal = strndup(pLiteral->z, pLiteral->n);
  CHECK_OUT_OF_MEM(val->literal);
D
dapan1121 已提交
343
  val->placeholderNo = ++pCxt->placeholderNo;
X
Xiaoyu Wang 已提交
344 345 346
  if (NULL == pCxt->pPlaceholderValues) {
    pCxt->pPlaceholderValues = taosArrayInit(TARRAY_MIN_SIZE, POINTER_BYTES);
    if (NULL == pCxt->pPlaceholderValues) {
347
      nodesDestroyNode((SNode*)val);
X
Xiaoyu Wang 已提交
348 349 350 351
      return NULL;
    }
  }
  taosArrayPush(pCxt->pPlaceholderValues, &val);
352 353 354
  return (SNode*)val;
}

X
Xiaoyu Wang 已提交
355 356 357 358 359 360 361 362 363 364 365
static int32_t addParamToLogicConditionNode(SLogicConditionNode* pCond, SNode* pParam) {
  if (QUERY_NODE_LOGIC_CONDITION == nodeType(pParam) && pCond->condType == ((SLogicConditionNode*)pParam)->condType) {
    int32_t code = nodesListAppendList(pCond->pParameterList, ((SLogicConditionNode*)pParam)->pParameterList);
    ((SLogicConditionNode*)pParam)->pParameterList = NULL;
    nodesDestroyNode(pParam);
    return code;
  } else {
    return nodesListAppend(pCond->pParameterList, pParam);
  }
}

366
SNode* createLogicConditionNode(SAstCreateContext* pCxt, ELogicConditionType type, SNode* pParam1, SNode* pParam2) {
X
Xiaoyu Wang 已提交
367
  CHECK_PARSER_STATUS(pCxt);
368 369 370 371
  SLogicConditionNode* cond = (SLogicConditionNode*)nodesMakeNode(QUERY_NODE_LOGIC_CONDITION);
  CHECK_OUT_OF_MEM(cond);
  cond->condType = type;
  cond->pParameterList = nodesMakeList();
X
Xiaoyu Wang 已提交
372 373 374
  int32_t code = addParamToLogicConditionNode(cond, pParam1);
  if (TSDB_CODE_SUCCESS == code && NULL != pParam2) {
    code = addParamToLogicConditionNode(cond, pParam2);
X
Xiaoyu Wang 已提交
375
  }
X
Xiaoyu Wang 已提交
376
  if (TSDB_CODE_SUCCESS != code) {
377
    nodesDestroyNode((SNode*)cond);
X
Xiaoyu Wang 已提交
378
    return NULL;
379
  }
380 381 382 383
  return (SNode*)cond;
}

SNode* createOperatorNode(SAstCreateContext* pCxt, EOperatorType type, SNode* pLeft, SNode* pRight) {
X
Xiaoyu Wang 已提交
384
  CHECK_PARSER_STATUS(pCxt);
385 386 387 388 389 390 391 392 393
  SOperatorNode* op = (SOperatorNode*)nodesMakeNode(QUERY_NODE_OPERATOR);
  CHECK_OUT_OF_MEM(op);
  op->opType = type;
  op->pLeft = pLeft;
  op->pRight = pRight;
  return (SNode*)op;
}

SNode* createBetweenAnd(SAstCreateContext* pCxt, SNode* pExpr, SNode* pLeft, SNode* pRight) {
X
Xiaoyu Wang 已提交
394
  CHECK_PARSER_STATUS(pCxt);
395
  return createLogicConditionNode(pCxt, LOGIC_COND_TYPE_AND,
X
Xiaoyu Wang 已提交
396 397
                                  createOperatorNode(pCxt, OP_TYPE_GREATER_EQUAL, pExpr, pLeft),
                                  createOperatorNode(pCxt, OP_TYPE_LOWER_EQUAL, nodesCloneNode(pExpr), pRight));
398 399 400
}

SNode* createNotBetweenAnd(SAstCreateContext* pCxt, SNode* pExpr, SNode* pLeft, SNode* pRight) {
X
Xiaoyu Wang 已提交
401
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
402 403
  return createLogicConditionNode(pCxt, LOGIC_COND_TYPE_OR, createOperatorNode(pCxt, OP_TYPE_LOWER_THAN, pExpr, pLeft),
                                  createOperatorNode(pCxt, OP_TYPE_GREATER_THAN, nodesCloneNode(pExpr), pRight));
404 405
}

X
Xiaoyu Wang 已提交
406
static SNode* createPrimaryKeyCol(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
407
  CHECK_PARSER_STATUS(pCxt);
408
  SColumnNode* pCol = (SColumnNode*)nodesMakeNode(QUERY_NODE_COLUMN);
X
Xiaoyu Wang 已提交
409 410 411 412 413 414
  CHECK_OUT_OF_MEM(pCol);
  pCol->colId = PRIMARYKEY_TIMESTAMP_COL_ID;
  strcpy(pCol->colName, PK_TS_COL_INTERNAL_NAME);
  return (SNode*)pCol;
}

415
SNode* createFunctionNode(SAstCreateContext* pCxt, const SToken* pFuncName, SNodeList* pParameterList) {
X
Xiaoyu Wang 已提交
416
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
417 418 419
  if (0 == strncasecmp("_rowts", pFuncName->z, pFuncName->n) || 0 == strncasecmp("_c0", pFuncName->z, pFuncName->n)) {
    return createPrimaryKeyCol(pCxt);
  }
420 421
  SFunctionNode* func = (SFunctionNode*)nodesMakeNode(QUERY_NODE_FUNCTION);
  CHECK_OUT_OF_MEM(func);
422
  COPY_STRING_FORM_ID_TOKEN(func->functionName, pFuncName);
423 424 425 426
  func->pParameterList = pParameterList;
  return (SNode*)func;
}

427
SNode* createCastFunctionNode(SAstCreateContext* pCxt, SNode* pExpr, SDataType dt) {
X
Xiaoyu Wang 已提交
428
  CHECK_PARSER_STATUS(pCxt);
429 430 431 432
  SFunctionNode* func = (SFunctionNode*)nodesMakeNode(QUERY_NODE_FUNCTION);
  CHECK_OUT_OF_MEM(func);
  strcpy(func->functionName, "cast");
  func->node.resType = dt;
433 434 435 436
  if (TSDB_DATA_TYPE_VARCHAR == dt.type) {
    func->node.resType.bytes = func->node.resType.bytes + VARSTR_HEADER_SIZE;
  } else if (TSDB_DATA_TYPE_NCHAR == dt.type) {
    func->node.resType.bytes = func->node.resType.bytes * TSDB_NCHAR_SIZE + VARSTR_HEADER_SIZE;
437
  }
438 439 440 441
  nodesListMakeAppend(&func->pParameterList, pExpr);
  return (SNode*)func;
}

442
SNode* createNodeListNode(SAstCreateContext* pCxt, SNodeList* pList) {
X
Xiaoyu Wang 已提交
443
  CHECK_PARSER_STATUS(pCxt);
444 445 446 447
  SNodeListNode* list = (SNodeListNode*)nodesMakeNode(QUERY_NODE_NODE_LIST);
  CHECK_OUT_OF_MEM(list);
  list->pNodeList = pList;
  return (SNode*)list;
448 449
}

X
Xiaoyu Wang 已提交
450
SNode* createNodeListNodeEx(SAstCreateContext* pCxt, SNode* p1, SNode* p2) {
X
Xiaoyu Wang 已提交
451
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
452 453 454 455 456 457 458 459 460
  SNodeListNode* list = (SNodeListNode*)nodesMakeNode(QUERY_NODE_NODE_LIST);
  CHECK_OUT_OF_MEM(list);
  list->pNodeList = nodesMakeList();
  CHECK_OUT_OF_MEM(list->pNodeList);
  nodesListAppend(list->pNodeList, p1);
  nodesListAppend(list->pNodeList, p2);
  return (SNode*)list;
}

X
Xiaoyu Wang 已提交
461
SNode* createRealTableNode(SAstCreateContext* pCxt, SToken* pDbName, SToken* pTableName, SToken* pTableAlias) {
X
Xiaoyu Wang 已提交
462
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
463
  if (!checkDbName(pCxt, pDbName, true) || !checkTableName(pCxt, pTableName) || !checkTableName(pCxt, pTableAlias)) {
464 465 466 467 468
    return NULL;
  }
  SRealTableNode* realTable = (SRealTableNode*)nodesMakeNode(QUERY_NODE_REAL_TABLE);
  CHECK_OUT_OF_MEM(realTable);
  if (NULL != pDbName) {
469
    COPY_STRING_FORM_ID_TOKEN(realTable->table.dbName, pDbName);
470 471 472
  } else {
    strcpy(realTable->table.dbName, pCxt->pQueryCxt->db);
  }
473
  if (NULL != pTableAlias && TK_NK_NIL != pTableAlias->type) {
474
    COPY_STRING_FORM_ID_TOKEN(realTable->table.tableAlias, pTableAlias);
475
  } else {
476
    COPY_STRING_FORM_ID_TOKEN(realTable->table.tableAlias, pTableName);
477
  }
478
  COPY_STRING_FORM_ID_TOKEN(realTable->table.tableName, pTableName);
479
  return (SNode*)realTable;
480
}
481

482
SNode* createTempTableNode(SAstCreateContext* pCxt, SNode* pSubquery, const SToken* pTableAlias) {
X
Xiaoyu Wang 已提交
483
  CHECK_PARSER_STATUS(pCxt);
484 485 486
  STempTableNode* tempTable = (STempTableNode*)nodesMakeNode(QUERY_NODE_TEMP_TABLE);
  CHECK_OUT_OF_MEM(tempTable);
  tempTable->pSubquery = pSubquery;
487
  if (NULL != pTableAlias && TK_NK_NIL != pTableAlias->type) {
488
    COPY_STRING_FORM_ID_TOKEN(tempTable->table.tableAlias, pTableAlias);
X
Xiaoyu Wang 已提交
489 490 491 492 493
  } else {
    sprintf(tempTable->table.tableAlias, "%p", tempTable);
  }
  if (QUERY_NODE_SELECT_STMT == nodeType(pSubquery)) {
    strcpy(((SSelectStmt*)pSubquery)->stmtName, tempTable->table.tableAlias);
494 495
  } else if (QUERY_NODE_SET_OPERATOR == nodeType(pSubquery)) {
    strcpy(((SSetOperator*)pSubquery)->stmtName, tempTable->table.tableAlias);
496
  }
497
  return (SNode*)tempTable;
498 499
}

500
SNode* createJoinTableNode(SAstCreateContext* pCxt, EJoinType type, SNode* pLeft, SNode* pRight, SNode* pJoinCond) {
X
Xiaoyu Wang 已提交
501
  CHECK_PARSER_STATUS(pCxt);
502 503 504
  SJoinTableNode* joinTable = (SJoinTableNode*)nodesMakeNode(QUERY_NODE_JOIN_TABLE);
  CHECK_OUT_OF_MEM(joinTable);
  joinTable->joinType = type;
505 506
  joinTable->pLeft = pLeft;
  joinTable->pRight = pRight;
507
  joinTable->pOnCond = pJoinCond;
508
  return (SNode*)joinTable;
509
}
510

511
SNode* createLimitNode(SAstCreateContext* pCxt, const SToken* pLimit, const SToken* pOffset) {
X
Xiaoyu Wang 已提交
512
  CHECK_PARSER_STATUS(pCxt);
513 514
  SLimitNode* limitNode = (SLimitNode*)nodesMakeNode(QUERY_NODE_LIMIT);
  CHECK_OUT_OF_MEM(limitNode);
wafwerar's avatar
wafwerar 已提交
515
  limitNode->limit = taosStr2Int64(pLimit->z, NULL, 10);
516
  if (NULL != pOffset) {
wafwerar's avatar
wafwerar 已提交
517
    limitNode->offset = taosStr2Int64(pOffset->z, NULL, 10);
518
  }
519
  return (SNode*)limitNode;
520 521
}

522
SNode* createOrderByExprNode(SAstCreateContext* pCxt, SNode* pExpr, EOrder order, ENullOrder nullOrder) {
X
Xiaoyu Wang 已提交
523
  CHECK_PARSER_STATUS(pCxt);
524 525
  SOrderByExprNode* orderByExpr = (SOrderByExprNode*)nodesMakeNode(QUERY_NODE_ORDER_BY_EXPR);
  CHECK_OUT_OF_MEM(orderByExpr);
526
  orderByExpr->pExpr = pExpr;
527
  orderByExpr->order = order;
528 529 530
  if (NULL_ORDER_DEFAULT == nullOrder) {
    nullOrder = (ORDER_ASC == order ? NULL_ORDER_FIRST : NULL_ORDER_LAST);
  }
531
  orderByExpr->nullOrder = nullOrder;
532 533 534
  return (SNode*)orderByExpr;
}

X
Xiaoyu Wang 已提交
535
SNode* createSessionWindowNode(SAstCreateContext* pCxt, SNode* pCol, SNode* pGap) {
X
Xiaoyu Wang 已提交
536
  CHECK_PARSER_STATUS(pCxt);
537 538
  SSessionWindowNode* session = (SSessionWindowNode*)nodesMakeNode(QUERY_NODE_SESSION_WINDOW);
  CHECK_OUT_OF_MEM(session);
X
Xiaoyu Wang 已提交
539 540
  session->pCol = (SColumnNode*)pCol;
  session->pGap = (SValueNode*)pGap;
541 542 543
  return (SNode*)session;
}

544
SNode* createStateWindowNode(SAstCreateContext* pCxt, SNode* pExpr) {
X
Xiaoyu Wang 已提交
545
  CHECK_PARSER_STATUS(pCxt);
546 547
  SStateWindowNode* state = (SStateWindowNode*)nodesMakeNode(QUERY_NODE_STATE_WINDOW);
  CHECK_OUT_OF_MEM(state);
X
Xiaoyu Wang 已提交
548
  state->pCol = createPrimaryKeyCol(pCxt);
549
  if (NULL == state->pCol) {
550
    nodesDestroyNode((SNode*)state);
551 552
    CHECK_OUT_OF_MEM(state->pCol);
  }
553
  state->pExpr = pExpr;
554 555 556
  return (SNode*)state;
}

X
Xiaoyu Wang 已提交
557 558
SNode* createIntervalWindowNode(SAstCreateContext* pCxt, SNode* pInterval, SNode* pOffset, SNode* pSliding,
                                SNode* pFill) {
X
Xiaoyu Wang 已提交
559
  CHECK_PARSER_STATUS(pCxt);
560 561
  SIntervalWindowNode* interval = (SIntervalWindowNode*)nodesMakeNode(QUERY_NODE_INTERVAL_WINDOW);
  CHECK_OUT_OF_MEM(interval);
X
Xiaoyu Wang 已提交
562
  interval->pCol = createPrimaryKeyCol(pCxt);
X
bugfix  
Xiaoyu Wang 已提交
563
  if (NULL == interval->pCol) {
564
    nodesDestroyNode((SNode*)interval);
X
bugfix  
Xiaoyu Wang 已提交
565 566
    CHECK_OUT_OF_MEM(interval->pCol);
  }
567 568 569 570 571 572 573 574
  interval->pInterval = pInterval;
  interval->pOffset = pOffset;
  interval->pSliding = pSliding;
  interval->pFill = pFill;
  return (SNode*)interval;
}

SNode* createFillNode(SAstCreateContext* pCxt, EFillMode mode, SNode* pValues) {
X
Xiaoyu Wang 已提交
575
  CHECK_PARSER_STATUS(pCxt);
576 577 578 579
  SFillNode* fill = (SFillNode*)nodesMakeNode(QUERY_NODE_FILL);
  CHECK_OUT_OF_MEM(fill);
  fill->mode = mode;
  fill->pValues = pValues;
X
Xiaoyu Wang 已提交
580 581
  fill->pWStartTs = nodesMakeNode(QUERY_NODE_FUNCTION);
  if (NULL == fill->pWStartTs) {
582
    nodesDestroyNode((SNode*)fill);
X
Xiaoyu Wang 已提交
583 584 585
    CHECK_OUT_OF_MEM(fill->pWStartTs);
  }
  strcpy(((SFunctionNode*)fill->pWStartTs)->functionName, "_wstartts");
586
  return (SNode*)fill;
587
}
588

589
SNode* createGroupingSetNode(SAstCreateContext* pCxt, SNode* pNode) {
X
Xiaoyu Wang 已提交
590
  CHECK_PARSER_STATUS(pCxt);
591 592 593 594 595 596 597 598
  SGroupingSetNode* groupingSet = (SGroupingSetNode*)nodesMakeNode(QUERY_NODE_GROUPING_SET);
  CHECK_OUT_OF_MEM(groupingSet);
  groupingSet->groupingSetType = GP_TYPE_NORMAL;
  groupingSet->pParameterList = nodesMakeList();
  nodesListAppend(groupingSet->pParameterList, pNode);
  return (SNode*)groupingSet;
}

599
SNode* setProjectionAlias(SAstCreateContext* pCxt, SNode* pNode, const SToken* pAlias) {
X
Xiaoyu Wang 已提交
600
  CHECK_PARSER_STATUS(pCxt);
D
dapan1121 已提交
601 602 603
  int32_t len = TMIN(sizeof(((SExprNode*)pNode)->aliasName) - 1, pAlias->n);
  strncpy(((SExprNode*)pNode)->aliasName, pAlias->z, len);
  ((SExprNode*)pNode)->aliasName[len] = '\0';
604 605
  strncpy(((SExprNode*)pNode)->userAlias, pAlias->z, len);
  ((SExprNode*)pNode)->userAlias[len] = '\0';
606
  return pNode;
607 608
}

609
SNode* addWhereClause(SAstCreateContext* pCxt, SNode* pStmt, SNode* pWhere) {
X
Xiaoyu Wang 已提交
610
  CHECK_PARSER_STATUS(pCxt);
611
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
612
    ((SSelectStmt*)pStmt)->pWhere = pWhere;
613 614 615
  }
  return pStmt;
}
616

617
SNode* addPartitionByClause(SAstCreateContext* pCxt, SNode* pStmt, SNodeList* pPartitionByList) {
X
Xiaoyu Wang 已提交
618
  CHECK_PARSER_STATUS(pCxt);
619
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
620
    ((SSelectStmt*)pStmt)->pPartitionByList = pPartitionByList;
621 622
  }
  return pStmt;
623 624
}

625
SNode* addWindowClauseClause(SAstCreateContext* pCxt, SNode* pStmt, SNode* pWindow) {
X
Xiaoyu Wang 已提交
626
  CHECK_PARSER_STATUS(pCxt);
627
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
628
    ((SSelectStmt*)pStmt)->pWindow = pWindow;
629 630 631
  }
  return pStmt;
}
632

633
SNode* addGroupByClause(SAstCreateContext* pCxt, SNode* pStmt, SNodeList* pGroupByList) {
X
Xiaoyu Wang 已提交
634
  CHECK_PARSER_STATUS(pCxt);
635
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
636
    ((SSelectStmt*)pStmt)->pGroupByList = pGroupByList;
637 638
  }
  return pStmt;
639 640
}

641
SNode* addHavingClause(SAstCreateContext* pCxt, SNode* pStmt, SNode* pHaving) {
X
Xiaoyu Wang 已提交
642
  CHECK_PARSER_STATUS(pCxt);
643
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
644
    ((SSelectStmt*)pStmt)->pHaving = pHaving;
645 646 647 648 649
  }
  return pStmt;
}

SNode* addOrderByClause(SAstCreateContext* pCxt, SNode* pStmt, SNodeList* pOrderByList) {
X
Xiaoyu Wang 已提交
650
  CHECK_PARSER_STATUS(pCxt);
651
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
652
    ((SSelectStmt*)pStmt)->pOrderByList = pOrderByList;
653 654
  } else {
    ((SSetOperator*)pStmt)->pOrderByList = pOrderByList;
655 656 657
  }
  return pStmt;
}
658

659
SNode* addSlimitClause(SAstCreateContext* pCxt, SNode* pStmt, SNode* pSlimit) {
X
Xiaoyu Wang 已提交
660
  CHECK_PARSER_STATUS(pCxt);
661
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
X
Xiaoyu Wang 已提交
662
    ((SSelectStmt*)pStmt)->pSlimit = (SLimitNode*)pSlimit;
663 664
  }
  return pStmt;
665 666
}

667
SNode* addLimitClause(SAstCreateContext* pCxt, SNode* pStmt, SNode* pLimit) {
X
Xiaoyu Wang 已提交
668
  CHECK_PARSER_STATUS(pCxt);
669
  if (QUERY_NODE_SELECT_STMT == nodeType(pStmt)) {
X
Xiaoyu Wang 已提交
670
    ((SSelectStmt*)pStmt)->pLimit = (SLimitNode*)pLimit;
671
  }
672
  return pStmt;
673 674 675
}

SNode* createSelectStmt(SAstCreateContext* pCxt, bool isDistinct, SNodeList* pProjectionList, SNode* pTable) {
X
Xiaoyu Wang 已提交
676
  CHECK_PARSER_STATUS(pCxt);
677
  SSelectStmt* select = (SSelectStmt*)nodesMakeNode(QUERY_NODE_SELECT_STMT);
678
  CHECK_OUT_OF_MEM(select);
679
  select->isDistinct = isDistinct;
680 681
  select->pProjectionList = pProjectionList;
  select->pFromTable = pTable;
X
Xiaoyu Wang 已提交
682
  sprintf(select->stmtName, "%p", select);
X
Xiaoyu Wang 已提交
683
  select->isTimeOrderQuery = true;
684
  return (SNode*)select;
685 686 687
}

SNode* createSetOperator(SAstCreateContext* pCxt, ESetOperatorType type, SNode* pLeft, SNode* pRight) {
X
Xiaoyu Wang 已提交
688
  CHECK_PARSER_STATUS(pCxt);
689 690 691
  SSetOperator* setOp = (SSetOperator*)nodesMakeNode(QUERY_NODE_SET_OPERATOR);
  CHECK_OUT_OF_MEM(setOp);
  setOp->opType = type;
692 693
  setOp->pLeft = pLeft;
  setOp->pRight = pRight;
694
  sprintf(setOp->stmtName, "%p", setOp);
695
  return (SNode*)setOp;
696 697
}

X
Xiaoyu Wang 已提交
698
SNode* createDefaultDatabaseOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
699
  CHECK_PARSER_STATUS(pCxt);
700
  SDatabaseOptions* pOptions = (SDatabaseOptions*)nodesMakeNode(QUERY_NODE_DATABASE_OPTIONS);
701
  CHECK_OUT_OF_MEM(pOptions);
X
Xiaoyu Wang 已提交
702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719
  pOptions->buffer = TSDB_DEFAULT_BUFFER_PER_VNODE;
  pOptions->cachelast = TSDB_DEFAULT_CACHE_LAST_ROW;
  pOptions->compressionLevel = TSDB_DEFAULT_COMP_LEVEL;
  pOptions->daysPerFile = TSDB_DEFAULT_DAYS_PER_FILE;
  pOptions->fsyncPeriod = TSDB_DEFAULT_FSYNC_PERIOD;
  pOptions->maxRowsPerBlock = TSDB_DEFAULT_MAXROWS_FBLOCK;
  pOptions->minRowsPerBlock = TSDB_DEFAULT_MINROWS_FBLOCK;
  pOptions->keep[0] = TSDB_DEFAULT_KEEP;
  pOptions->keep[1] = TSDB_DEFAULT_KEEP;
  pOptions->keep[2] = TSDB_DEFAULT_KEEP;
  pOptions->pages = TSDB_DEFAULT_PAGES_PER_VNODE;
  pOptions->pagesize = TSDB_DEFAULT_PAGESIZE_PER_VNODE;
  pOptions->precision = TSDB_DEFAULT_PRECISION;
  pOptions->replica = TSDB_DEFAULT_DB_REPLICA;
  pOptions->strict = TSDB_DEFAULT_DB_STRICT;
  pOptions->walLevel = TSDB_DEFAULT_WAL_LEVEL;
  pOptions->numOfVgroups = TSDB_DEFAULT_VN_PER_DB;
  pOptions->singleStable = TSDB_DEFAULT_DB_SINGLE_STABLE;
X
Xiaoyu Wang 已提交
720
  pOptions->schemaless = TSDB_DEFAULT_DB_SCHEMALESS;
X
Xiaoyu Wang 已提交
721
  return (SNode*)pOptions;
722 723
}

X
Xiaoyu Wang 已提交
724
SNode* createAlterDatabaseOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
725
  CHECK_PARSER_STATUS(pCxt);
726
  SDatabaseOptions* pOptions = (SDatabaseOptions*)nodesMakeNode(QUERY_NODE_DATABASE_OPTIONS);
X
Xiaoyu Wang 已提交
727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745
  CHECK_OUT_OF_MEM(pOptions);
  pOptions->buffer = -1;
  pOptions->cachelast = -1;
  pOptions->compressionLevel = -1;
  pOptions->daysPerFile = -1;
  pOptions->fsyncPeriod = -1;
  pOptions->maxRowsPerBlock = -1;
  pOptions->minRowsPerBlock = -1;
  pOptions->keep[0] = -1;
  pOptions->keep[1] = -1;
  pOptions->keep[2] = -1;
  pOptions->pages = -1;
  pOptions->pagesize = -1;
  pOptions->precision = -1;
  pOptions->replica = -1;
  pOptions->strict = -1;
  pOptions->walLevel = -1;
  pOptions->numOfVgroups = -1;
  pOptions->singleStable = -1;
X
Xiaoyu Wang 已提交
746
  pOptions->schemaless = -1;
X
Xiaoyu Wang 已提交
747 748 749 750
  return (SNode*)pOptions;
}

SNode* setDatabaseOption(SAstCreateContext* pCxt, SNode* pOptions, EDatabaseOptionType type, void* pVal) {
X
Xiaoyu Wang 已提交
751
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
752 753
  switch (type) {
    case DB_OPTION_BUFFER:
wafwerar's avatar
wafwerar 已提交
754
      ((SDatabaseOptions*)pOptions)->buffer = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
755 756
      break;
    case DB_OPTION_CACHELAST:
wafwerar's avatar
wafwerar 已提交
757
      ((SDatabaseOptions*)pOptions)->cachelast = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
758 759
      break;
    case DB_OPTION_COMP:
wafwerar's avatar
wafwerar 已提交
760
      ((SDatabaseOptions*)pOptions)->compressionLevel = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
761
      break;
X
Xiaoyu Wang 已提交
762 763 764
    case DB_OPTION_DAYS: {
      SToken* pToken = pVal;
      if (TK_NK_INTEGER == pToken->type) {
wafwerar's avatar
wafwerar 已提交
765
        ((SDatabaseOptions*)pOptions)->daysPerFile = taosStr2Int32(pToken->z, NULL, 10) * 1440;
X
Xiaoyu Wang 已提交
766 767 768
      } else {
        ((SDatabaseOptions*)pOptions)->pDaysPerFile = (SValueNode*)createDurationValueNode(pCxt, pToken);
      }
X
Xiaoyu Wang 已提交
769
      break;
X
Xiaoyu Wang 已提交
770
    }
X
Xiaoyu Wang 已提交
771
    case DB_OPTION_FSYNC:
wafwerar's avatar
wafwerar 已提交
772
      ((SDatabaseOptions*)pOptions)->fsyncPeriod = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
773 774
      break;
    case DB_OPTION_MAXROWS:
wafwerar's avatar
wafwerar 已提交
775
      ((SDatabaseOptions*)pOptions)->maxRowsPerBlock = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
776 777
      break;
    case DB_OPTION_MINROWS:
wafwerar's avatar
wafwerar 已提交
778
      ((SDatabaseOptions*)pOptions)->minRowsPerBlock = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
779 780
      break;
    case DB_OPTION_KEEP:
X
Xiaoyu Wang 已提交
781 782 783
      ((SDatabaseOptions*)pOptions)->pKeep = pVal;
      break;
    case DB_OPTION_PAGES:
wafwerar's avatar
wafwerar 已提交
784
      ((SDatabaseOptions*)pOptions)->pages = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
785 786
      break;
    case DB_OPTION_PAGESIZE:
wafwerar's avatar
wafwerar 已提交
787
      ((SDatabaseOptions*)pOptions)->pagesize = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
788 789
      break;
    case DB_OPTION_PRECISION:
790
      COPY_STRING_FORM_STR_TOKEN(((SDatabaseOptions*)pOptions)->precisionStr, (SToken*)pVal);
X
Xiaoyu Wang 已提交
791 792
      break;
    case DB_OPTION_REPLICA:
wafwerar's avatar
wafwerar 已提交
793
      ((SDatabaseOptions*)pOptions)->replica = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
794
      break;
X
Xiaoyu Wang 已提交
795
    case DB_OPTION_STRICT:
wafwerar's avatar
wafwerar 已提交
796
      ((SDatabaseOptions*)pOptions)->strict = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
797 798
      break;
    case DB_OPTION_WAL:
wafwerar's avatar
wafwerar 已提交
799
      ((SDatabaseOptions*)pOptions)->walLevel = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
800 801
      break;
    case DB_OPTION_VGROUPS:
wafwerar's avatar
wafwerar 已提交
802
      ((SDatabaseOptions*)pOptions)->numOfVgroups = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
803 804
      break;
    case DB_OPTION_SINGLE_STABLE:
wafwerar's avatar
wafwerar 已提交
805
      ((SDatabaseOptions*)pOptions)->singleStable = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
806 807
      break;
    case DB_OPTION_RETENTIONS:
X
Xiaoyu Wang 已提交
808
      ((SDatabaseOptions*)pOptions)->pRetentions = pVal;
X
Xiaoyu Wang 已提交
809
      break;
X
Xiaoyu Wang 已提交
810 811 812 813
      //    case DB_OPTION_SCHEMALESS:
      //      ((SDatabaseOptions*)pOptions)->schemaless = taosStr2Int8(((SToken*)pVal)->z, NULL, 10);
      //      ((SDatabaseOptions*)pOptions)->schemaless = 0;
      //      break;
X
Xiaoyu Wang 已提交
814 815
    default:
      break;
X
Xiaoyu Wang 已提交
816
  }
X
Xiaoyu Wang 已提交
817
  return pOptions;
X
Xiaoyu Wang 已提交
818 819
}

X
Xiaoyu Wang 已提交
820
SNode* setAlterDatabaseOption(SAstCreateContext* pCxt, SNode* pOptions, SAlterOption* pAlterOption) {
X
Xiaoyu Wang 已提交
821
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
822 823 824 825 826 827 828 829 830 831
  switch (pAlterOption->type) {
    case DB_OPTION_KEEP:
    case DB_OPTION_RETENTIONS:
      return setDatabaseOption(pCxt, pOptions, pAlterOption->type, pAlterOption->pList);
    default:
      break;
  }
  return setDatabaseOption(pCxt, pOptions, pAlterOption->type, &pAlterOption->val);
}

X
Xiaoyu Wang 已提交
832
SNode* createCreateDatabaseStmt(SAstCreateContext* pCxt, bool ignoreExists, SToken* pDbName, SNode* pOptions) {
X
Xiaoyu Wang 已提交
833
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
834
  if (!checkDbName(pCxt, pDbName, false)) {
835 836 837 838
    return NULL;
  }
  SCreateDatabaseStmt* pStmt = (SCreateDatabaseStmt*)nodesMakeNode(QUERY_NODE_CREATE_DATABASE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
839
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
840
  pStmt->ignoreExists = ignoreExists;
X
Xiaoyu Wang 已提交
841
  pStmt->pOptions = (SDatabaseOptions*)pOptions;
842
  return (SNode*)pStmt;
843
}
X
Xiaoyu Wang 已提交
844

X
Xiaoyu Wang 已提交
845
SNode* createDropDatabaseStmt(SAstCreateContext* pCxt, bool ignoreNotExists, SToken* pDbName) {
X
Xiaoyu Wang 已提交
846
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
847
  if (!checkDbName(pCxt, pDbName, false)) {
848 849 850 851
    return NULL;
  }
  SDropDatabaseStmt* pStmt = (SDropDatabaseStmt*)nodesMakeNode(QUERY_NODE_DROP_DATABASE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
852
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
853 854 855 856
  pStmt->ignoreNotExists = ignoreNotExists;
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
857
SNode* createAlterDatabaseStmt(SAstCreateContext* pCxt, SToken* pDbName, SNode* pOptions) {
X
Xiaoyu Wang 已提交
858
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
859
  if (!checkDbName(pCxt, pDbName, false)) {
860 861
    return NULL;
  }
862
  SAlterDatabaseStmt* pStmt = (SAlterDatabaseStmt*)nodesMakeNode(QUERY_NODE_ALTER_DATABASE_STMT);
863
  CHECK_OUT_OF_MEM(pStmt);
864
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
865 866 867 868
  pStmt->pOptions = (SDatabaseOptions*)pOptions;
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
869
SNode* createDefaultTableOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
870
  CHECK_PARSER_STATUS(pCxt);
871
  STableOptions* pOptions = (STableOptions*)nodesMakeNode(QUERY_NODE_TABLE_OPTIONS);
872
  CHECK_OUT_OF_MEM(pOptions);
X
Xiaoyu Wang 已提交
873 874 875 876
  pOptions->maxDelay1 = -1;
  pOptions->maxDelay2 = -1;
  pOptions->watermark1 = TSDB_DEFAULT_ROLLUP_WATERMARK;
  pOptions->watermark2 = TSDB_DEFAULT_ROLLUP_WATERMARK;
X
Xiaoyu Wang 已提交
877
  pOptions->ttl = TSDB_DEFAULT_TABLE_TTL;
878
  return (SNode*)pOptions;
X
Xiaoyu Wang 已提交
879 880
}

X
Xiaoyu Wang 已提交
881
SNode* createAlterTableOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
882
  CHECK_PARSER_STATUS(pCxt);
883
  STableOptions* pOptions = (STableOptions*)nodesMakeNode(QUERY_NODE_TABLE_OPTIONS);
X
Xiaoyu Wang 已提交
884 885 886 887 888 889
  CHECK_OUT_OF_MEM(pOptions);
  pOptions->ttl = -1;
  return (SNode*)pOptions;
}

SNode* setTableOption(SAstCreateContext* pCxt, SNode* pOptions, ETableOptionType type, void* pVal) {
X
Xiaoyu Wang 已提交
890
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
891
  switch (type) {
X
Xiaoyu Wang 已提交
892
    case TABLE_OPTION_COMMENT:
893
      if (checkComment(pCxt, (SToken*)pVal, true)) {
894
        COPY_STRING_FORM_STR_TOKEN(((STableOptions*)pOptions)->comment, (SToken*)pVal);
895
      }
X
Xiaoyu Wang 已提交
896
      break;
X
Xiaoyu Wang 已提交
897 898 899 900 901
    case TABLE_OPTION_MAXDELAY:
      ((STableOptions*)pOptions)->pMaxDelay = pVal;
      break;
    case TABLE_OPTION_WATERMARK:
      ((STableOptions*)pOptions)->pWatermark = pVal;
X
Xiaoyu Wang 已提交
902
      break;
X
Xiaoyu Wang 已提交
903 904 905 906
    case TABLE_OPTION_ROLLUP:
      ((STableOptions*)pOptions)->pRollupFuncs = pVal;
      break;
    case TABLE_OPTION_TTL:
wafwerar's avatar
wafwerar 已提交
907
      ((STableOptions*)pOptions)->ttl = taosStr2Int32(((SToken*)pVal)->z, NULL, 10);
X
Xiaoyu Wang 已提交
908 909 910
      break;
    case TABLE_OPTION_SMA:
      ((STableOptions*)pOptions)->pSma = pVal;
X
Xiaoyu Wang 已提交
911 912 913
      break;
    default:
      break;
X
Xiaoyu Wang 已提交
914
  }
X
Xiaoyu Wang 已提交
915
  return pOptions;
X
Xiaoyu Wang 已提交
916 917
}

X
Xiaoyu Wang 已提交
918
SNode* createColumnDefNode(SAstCreateContext* pCxt, SToken* pColName, SDataType dataType, const SToken* pComment) {
X
Xiaoyu Wang 已提交
919
  CHECK_PARSER_STATUS(pCxt);
920
  if (!checkColumnName(pCxt, pColName) || !checkComment(pCxt, pComment, false)) {
X
Xiaoyu Wang 已提交
921 922
    return NULL;
  }
X
Xiaoyu Wang 已提交
923 924
  SColumnDefNode* pCol = (SColumnDefNode*)nodesMakeNode(QUERY_NODE_COLUMN_DEF);
  CHECK_OUT_OF_MEM(pCol);
925
  COPY_STRING_FORM_ID_TOKEN(pCol->colName, pColName);
X
Xiaoyu Wang 已提交
926 927
  pCol->dataType = dataType;
  if (NULL != pComment) {
928
    trimString(pComment->z, pComment->n, pCol->comments, sizeof(pCol->comments));
X
Xiaoyu Wang 已提交
929
  }
930
  pCol->sma = true;
X
Xiaoyu Wang 已提交
931 932 933
  return (SNode*)pCol;
}

934
SDataType createDataType(uint8_t type) {
X
Xiaoyu Wang 已提交
935
  SDataType dt = {.type = type, .precision = 0, .scale = 0, .bytes = tDataTypes[type].bytes};
936 937 938 939
  return dt;
}

SDataType createVarLenDataType(uint8_t type, const SToken* pLen) {
wafwerar's avatar
wafwerar 已提交
940
  SDataType dt = {.type = type, .precision = 0, .scale = 0, .bytes = taosStr2Int16(pLen->z, NULL, 10)};
941 942 943
  return dt;
}

X
Xiaoyu Wang 已提交
944 945
SNode* createCreateTableStmt(SAstCreateContext* pCxt, bool ignoreExists, SNode* pRealTable, SNodeList* pCols,
                             SNodeList* pTags, SNode* pOptions) {
X
Xiaoyu Wang 已提交
946
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
947 948
  SCreateTableStmt* pStmt = (SCreateTableStmt*)nodesMakeNode(QUERY_NODE_CREATE_TABLE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
949 950
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
X
Xiaoyu Wang 已提交
951 952
  pStmt->ignoreExists = ignoreExists;
  pStmt->pCols = pCols;
953
  pStmt->pTags = pTags;
X
Xiaoyu Wang 已提交
954
  pStmt->pOptions = (STableOptions*)pOptions;
955
  nodesDestroyNode(pRealTable);
X
Xiaoyu Wang 已提交
956 957
  return (SNode*)pStmt;
}
958

X
Xiaoyu Wang 已提交
959
SNode* createCreateSubTableClause(SAstCreateContext* pCxt, bool ignoreExists, SNode* pRealTable, SNode* pUseRealTable,
X
Xiaoyu Wang 已提交
960
                                  SNodeList* pSpecificTags, SNodeList* pValsOfTags, SNode* pOptions) {
X
Xiaoyu Wang 已提交
961
  CHECK_PARSER_STATUS(pCxt);
962
  SCreateSubTableClause* pStmt = (SCreateSubTableClause*)nodesMakeNode(QUERY_NODE_CREATE_SUBTABLE_CLAUSE);
963
  CHECK_OUT_OF_MEM(pStmt);
964 965 966 967
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  strcpy(pStmt->useDbName, ((SRealTableNode*)pUseRealTable)->table.dbName);
  strcpy(pStmt->useTableName, ((SRealTableNode*)pUseRealTable)->table.tableName);
968 969 970
  pStmt->ignoreExists = ignoreExists;
  pStmt->pSpecificTags = pSpecificTags;
  pStmt->pValsOfTags = pValsOfTags;
971 972
  nodesDestroyNode(pRealTable);
  nodesDestroyNode(pUseRealTable);
973
  nodesDestroyNode(pOptions);
974 975 976 977
  return (SNode*)pStmt;
}

SNode* createCreateMultiTableStmt(SAstCreateContext* pCxt, SNodeList* pSubTables) {
X
Xiaoyu Wang 已提交
978
  CHECK_PARSER_STATUS(pCxt);
979
  SCreateMultiTableStmt* pStmt = (SCreateMultiTableStmt*)nodesMakeNode(QUERY_NODE_CREATE_MULTI_TABLE_STMT);
980 981 982 983 984
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->pSubTables = pSubTables;
  return (SNode*)pStmt;
}

985
SNode* createDropTableClause(SAstCreateContext* pCxt, bool ignoreNotExists, SNode* pRealTable) {
X
Xiaoyu Wang 已提交
986
  CHECK_PARSER_STATUS(pCxt);
987
  SDropTableClause* pStmt = (SDropTableClause*)nodesMakeNode(QUERY_NODE_DROP_TABLE_CLAUSE);
988 989 990 991 992 993 994 995 996
  CHECK_OUT_OF_MEM(pStmt);
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  pStmt->ignoreNotExists = ignoreNotExists;
  nodesDestroyNode(pRealTable);
  return (SNode*)pStmt;
}

SNode* createDropTableStmt(SAstCreateContext* pCxt, SNodeList* pTables) {
X
Xiaoyu Wang 已提交
997
  CHECK_PARSER_STATUS(pCxt);
998
  SDropTableStmt* pStmt = (SDropTableStmt*)nodesMakeNode(QUERY_NODE_DROP_TABLE_STMT);
999 1000 1001 1002 1003
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->pTables = pTables;
  return (SNode*)pStmt;
}

1004
SNode* createDropSuperTableStmt(SAstCreateContext* pCxt, bool ignoreNotExists, SNode* pRealTable) {
X
Xiaoyu Wang 已提交
1005
  CHECK_PARSER_STATUS(pCxt);
1006
  SDropSuperTableStmt* pStmt = (SDropSuperTableStmt*)nodesMakeNode(QUERY_NODE_DROP_SUPER_TABLE_STMT);
1007 1008 1009 1010 1011 1012 1013 1014
  CHECK_OUT_OF_MEM(pStmt);
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  pStmt->ignoreNotExists = ignoreNotExists;
  nodesDestroyNode(pRealTable);
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1015 1016 1017 1018 1019 1020 1021
static SNode* createAlterTableStmtFinalize(SNode* pRealTable, SAlterTableStmt* pStmt) {
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  nodesDestroyNode(pRealTable);
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1022
SNode* createAlterTableModifyOptions(SAstCreateContext* pCxt, SNode* pRealTable, SNode* pOptions) {
X
Xiaoyu Wang 已提交
1023
  CHECK_PARSER_STATUS(pCxt);
1024
  SAlterTableStmt* pStmt = (SAlterTableStmt*)nodesMakeNode(QUERY_NODE_ALTER_TABLE_STMT);
1025 1026 1027
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->alterType = TSDB_ALTER_TABLE_UPDATE_OPTIONS;
  pStmt->pOptions = (STableOptions*)pOptions;
X
Xiaoyu Wang 已提交
1028
  return createAlterTableStmtFinalize(pRealTable, pStmt);
1029 1030
}

X
Xiaoyu Wang 已提交
1031 1032
SNode* createAlterTableAddModifyCol(SAstCreateContext* pCxt, SNode* pRealTable, int8_t alterType, SToken* pColName,
                                    SDataType dataType) {
X
Xiaoyu Wang 已提交
1033 1034
  CHECK_PARSER_STATUS(pCxt);
  if (!checkColumnName(pCxt, pColName)) {
X
bugfix  
Xiaoyu Wang 已提交
1035 1036
    return NULL;
  }
1037
  SAlterTableStmt* pStmt = (SAlterTableStmt*)nodesMakeNode(QUERY_NODE_ALTER_TABLE_STMT);
1038 1039
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->alterType = alterType;
1040
  COPY_STRING_FORM_ID_TOKEN(pStmt->colName, pColName);
1041
  pStmt->dataType = dataType;
X
Xiaoyu Wang 已提交
1042
  return createAlterTableStmtFinalize(pRealTable, pStmt);
1043 1044
}

X
Xiaoyu Wang 已提交
1045
SNode* createAlterTableDropCol(SAstCreateContext* pCxt, SNode* pRealTable, int8_t alterType, SToken* pColName) {
X
Xiaoyu Wang 已提交
1046 1047
  CHECK_PARSER_STATUS(pCxt);
  if (!checkColumnName(pCxt, pColName)) {
X
bugfix  
Xiaoyu Wang 已提交
1048 1049
    return NULL;
  }
1050
  SAlterTableStmt* pStmt = (SAlterTableStmt*)nodesMakeNode(QUERY_NODE_ALTER_TABLE_STMT);
1051 1052
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->alterType = alterType;
1053
  COPY_STRING_FORM_ID_TOKEN(pStmt->colName, pColName);
X
Xiaoyu Wang 已提交
1054
  return createAlterTableStmtFinalize(pRealTable, pStmt);
1055 1056
}

X
Xiaoyu Wang 已提交
1057 1058
SNode* createAlterTableRenameCol(SAstCreateContext* pCxt, SNode* pRealTable, int8_t alterType, SToken* pOldColName,
                                 SToken* pNewColName) {
X
Xiaoyu Wang 已提交
1059 1060
  CHECK_PARSER_STATUS(pCxt);
  if (!checkColumnName(pCxt, pOldColName) || !checkColumnName(pCxt, pNewColName)) {
X
bugfix  
Xiaoyu Wang 已提交
1061 1062
    return NULL;
  }
1063
  SAlterTableStmt* pStmt = (SAlterTableStmt*)nodesMakeNode(QUERY_NODE_ALTER_TABLE_STMT);
1064 1065
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->alterType = alterType;
1066 1067
  COPY_STRING_FORM_ID_TOKEN(pStmt->colName, pOldColName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->newColName, pNewColName);
X
Xiaoyu Wang 已提交
1068
  return createAlterTableStmtFinalize(pRealTable, pStmt);
1069 1070
}

X
Xiaoyu Wang 已提交
1071
SNode* createAlterTableSetTag(SAstCreateContext* pCxt, SNode* pRealTable, SToken* pTagName, SNode* pVal) {
X
Xiaoyu Wang 已提交
1072 1073
  CHECK_PARSER_STATUS(pCxt);
  if (!checkColumnName(pCxt, pTagName)) {
X
bugfix  
Xiaoyu Wang 已提交
1074 1075
    return NULL;
  }
1076
  SAlterTableStmt* pStmt = (SAlterTableStmt*)nodesMakeNode(QUERY_NODE_ALTER_TABLE_STMT);
1077 1078
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->alterType = TSDB_ALTER_TABLE_UPDATE_TAG_VAL;
1079
  COPY_STRING_FORM_ID_TOKEN(pStmt->colName, pTagName);
1080
  pStmt->pVal = (SValueNode*)pVal;
X
Xiaoyu Wang 已提交
1081
  return createAlterTableStmtFinalize(pRealTable, pStmt);
1082 1083
}

1084
SNode* createUseDatabaseStmt(SAstCreateContext* pCxt, SToken* pDbName) {
X
Xiaoyu Wang 已提交
1085
  CHECK_PARSER_STATUS(pCxt);
1086 1087 1088
  if (!checkDbName(pCxt, pDbName, false)) {
    return NULL;
  }
1089 1090
  SUseDatabaseStmt* pStmt = (SUseDatabaseStmt*)nodesMakeNode(QUERY_NODE_USE_DATABASE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
1091
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
1092 1093 1094
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1095
static bool needDbShowStmt(ENodeType type) {
X
Xiaoyu Wang 已提交
1096 1097
  return QUERY_NODE_SHOW_TABLES_STMT == type || QUERY_NODE_SHOW_STABLES_STMT == type ||
         QUERY_NODE_SHOW_VGROUPS_STMT == type;
X
Xiaoyu Wang 已提交
1098 1099
}

X
Xiaoyu Wang 已提交
1100
SNode* createShowStmt(SAstCreateContext* pCxt, ENodeType type, SNode* pDbName, SNode* pTbNamePattern) {
X
Xiaoyu Wang 已提交
1101
  CHECK_PARSER_STATUS(pCxt);
X
Xiaoyu Wang 已提交
1102 1103
  if (needDbShowStmt(type) && NULL == pDbName && NULL == pCxt->pQueryCxt->db) {
    snprintf(pCxt->pQueryCxt->pMsg, pCxt->pQueryCxt->msgLen, "db not specified");
1104
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
X
Xiaoyu Wang 已提交
1105 1106
    return NULL;
  }
1107
  SShowStmt* pStmt = (SShowStmt*)nodesMakeNode(type);
1108
  CHECK_OUT_OF_MEM(pStmt);
X
Xiaoyu Wang 已提交
1109 1110
  pStmt->pDbName = pDbName;
  pStmt->pTbNamePattern = pTbNamePattern;
1111
  return (SNode*)pStmt;
1112
}
1113

1114
SNode* createShowCreateDatabaseStmt(SAstCreateContext* pCxt, SToken* pDbName) {
X
Xiaoyu Wang 已提交
1115
  CHECK_PARSER_STATUS(pCxt);
1116 1117 1118 1119
  if (!checkDbName(pCxt, pDbName, true)) {
    return NULL;
  }
  SShowCreateDatabaseStmt* pStmt = (SShowCreateDatabaseStmt*)nodesMakeNode(QUERY_NODE_SHOW_CREATE_DATABASE_STMT);
1120
  CHECK_OUT_OF_MEM(pStmt);
1121 1122
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
  return (SNode*)pStmt;
1123 1124 1125
}

SNode* createShowCreateTableStmt(SAstCreateContext* pCxt, ENodeType type, SNode* pRealTable) {
X
Xiaoyu Wang 已提交
1126
  CHECK_PARSER_STATUS(pCxt);
1127
  SShowCreateTableStmt* pStmt = (SShowCreateTableStmt*)nodesMakeNode(type);
1128
  CHECK_OUT_OF_MEM(pStmt);
1129 1130 1131
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  return (SNode*)pStmt;
1132 1133
}

X
Xiaoyu Wang 已提交
1134
SNode* createCreateUserStmt(SAstCreateContext* pCxt, SToken* pUserName, const SToken* pPassword) {
X
Xiaoyu Wang 已提交
1135
  CHECK_PARSER_STATUS(pCxt);
1136 1137 1138 1139 1140 1141
  char password[TSDB_USET_PASSWORD_LEN] = {0};
  if (!checkUserName(pCxt, pUserName) || !checkPassword(pCxt, pPassword, password)) {
    return NULL;
  }
  SCreateUserStmt* pStmt = (SCreateUserStmt*)nodesMakeNode(QUERY_NODE_CREATE_USER_STMT);
  CHECK_OUT_OF_MEM(pStmt);
1142
  COPY_STRING_FORM_ID_TOKEN(pStmt->useName, pUserName);
1143 1144 1145 1146
  strcpy(pStmt->password, password);
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1147
SNode* createAlterUserStmt(SAstCreateContext* pCxt, SToken* pUserName, int8_t alterType, const SToken* pVal) {
X
Xiaoyu Wang 已提交
1148
  CHECK_PARSER_STATUS(pCxt);
1149 1150 1151 1152 1153
  if (!checkUserName(pCxt, pUserName)) {
    return NULL;
  }
  SAlterUserStmt* pStmt = (SAlterUserStmt*)nodesMakeNode(QUERY_NODE_ALTER_USER_STMT);
  CHECK_OUT_OF_MEM(pStmt);
1154
  COPY_STRING_FORM_ID_TOKEN(pStmt->useName, pUserName);
1155 1156 1157
  if (TSDB_ALTER_USER_PASSWD == alterType) {
    char password[TSDB_USET_PASSWORD_LEN] = {0};
    if (!checkPassword(pCxt, pVal, password)) {
1158
      nodesDestroyNode((SNode*)pStmt);
1159 1160 1161 1162 1163 1164 1165 1166
      return NULL;
    }
    strcpy(pStmt->password, password);
  }
  pStmt->alterType = alterType;
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1167
SNode* createDropUserStmt(SAstCreateContext* pCxt, SToken* pUserName) {
X
Xiaoyu Wang 已提交
1168
  CHECK_PARSER_STATUS(pCxt);
1169 1170 1171 1172 1173
  if (!checkUserName(pCxt, pUserName)) {
    return NULL;
  }
  SDropUserStmt* pStmt = (SDropUserStmt*)nodesMakeNode(QUERY_NODE_DROP_USER_STMT);
  CHECK_OUT_OF_MEM(pStmt);
1174
  COPY_STRING_FORM_ID_TOKEN(pStmt->useName, pUserName);
1175 1176 1177 1178
  return (SNode*)pStmt;
}

SNode* createCreateDnodeStmt(SAstCreateContext* pCxt, const SToken* pFqdn, const SToken* pPort) {
X
Xiaoyu Wang 已提交
1179
  CHECK_PARSER_STATUS(pCxt);
1180
  int32_t port = 0;
X
Xiaoyu Wang 已提交
1181
  char    fqdn[TSDB_FQDN_LEN] = {0};
1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193
  if (NULL == pPort) {
    if (!checkAndSplitEndpoint(pCxt, pFqdn, fqdn, &port)) {
      return NULL;
    }
  } else if (!checkFqdn(pCxt, pFqdn) || !checkPort(pCxt, pPort, &port)) {
    return NULL;
  }
  SCreateDnodeStmt* pStmt = (SCreateDnodeStmt*)nodesMakeNode(QUERY_NODE_CREATE_DNODE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
  if (NULL == pPort) {
    strcpy(pStmt->fqdn, fqdn);
  } else {
1194
    COPY_STRING_FORM_ID_TOKEN(pStmt->fqdn, pFqdn);
1195 1196 1197 1198 1199 1200
  }
  pStmt->port = port;
  return (SNode*)pStmt;
}

SNode* createDropDnodeStmt(SAstCreateContext* pCxt, const SToken* pDnode) {
X
Xiaoyu Wang 已提交
1201
  CHECK_PARSER_STATUS(pCxt);
1202 1203 1204
  SDropDnodeStmt* pStmt = (SDropDnodeStmt*)nodesMakeNode(QUERY_NODE_DROP_DNODE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
  if (TK_NK_INTEGER == pDnode->type) {
wafwerar's avatar
wafwerar 已提交
1205
    pStmt->dnodeId = taosStr2Int32(pDnode->z, NULL, 10);
1206 1207
  } else {
    if (!checkAndSplitEndpoint(pCxt, pDnode, pStmt->fqdn, &pStmt->port)) {
1208
      nodesDestroyNode((SNode*)pStmt);
1209 1210 1211 1212 1213
      return NULL;
    }
  }
  return (SNode*)pStmt;
}
X
Xiaoyu Wang 已提交
1214

X
Xiaoyu Wang 已提交
1215 1216
SNode* createAlterDnodeStmt(SAstCreateContext* pCxt, const SToken* pDnode, const SToken* pConfig,
                            const SToken* pValue) {
X
Xiaoyu Wang 已提交
1217
  CHECK_PARSER_STATUS(pCxt);
1218
  SAlterDnodeStmt* pStmt = (SAlterDnodeStmt*)nodesMakeNode(QUERY_NODE_ALTER_DNODE_STMT);
1219
  CHECK_OUT_OF_MEM(pStmt);
wafwerar's avatar
wafwerar 已提交
1220
  pStmt->dnodeId = taosStr2Int32(pDnode->z, NULL, 10);
1221 1222 1223 1224 1225 1226 1227
  trimString(pConfig->z, pConfig->n, pStmt->config, sizeof(pStmt->config));
  if (NULL != pValue) {
    trimString(pValue->z, pValue->n, pStmt->value, sizeof(pStmt->value));
  }
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1228 1229
SNode* createCreateIndexStmt(SAstCreateContext* pCxt, EIndexType type, bool ignoreExists, SToken* pIndexName,
                             SToken* pTableName, SNodeList* pCols, SNode* pOptions) {
X
Xiaoyu Wang 已提交
1230
  CHECK_PARSER_STATUS(pCxt);
1231
  if (!checkIndexName(pCxt, pIndexName) || !checkTableName(pCxt, pTableName) || !checkDbName(pCxt, NULL, true)) {
X
Xiaoyu Wang 已提交
1232 1233
    return NULL;
  }
1234
  SCreateIndexStmt* pStmt = (SCreateIndexStmt*)nodesMakeNode(QUERY_NODE_CREATE_INDEX_STMT);
X
Xiaoyu Wang 已提交
1235 1236
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->indexType = type;
X
Xiaoyu Wang 已提交
1237
  pStmt->ignoreExists = ignoreExists;
1238 1239
  COPY_STRING_FORM_ID_TOKEN(pStmt->indexName, pIndexName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->tableName, pTableName);
X
Xiaoyu Wang 已提交
1240 1241 1242 1243 1244
  pStmt->pCols = pCols;
  pStmt->pOptions = (SIndexOptions*)pOptions;
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1245 1246
SNode* createIndexOption(SAstCreateContext* pCxt, SNodeList* pFuncs, SNode* pInterval, SNode* pOffset,
                         SNode* pSliding) {
X
Xiaoyu Wang 已提交
1247
  CHECK_PARSER_STATUS(pCxt);
1248
  SIndexOptions* pOptions = (SIndexOptions*)nodesMakeNode(QUERY_NODE_INDEX_OPTIONS);
X
Xiaoyu Wang 已提交
1249 1250 1251 1252 1253 1254 1255
  CHECK_OUT_OF_MEM(pOptions);
  pOptions->pFuncs = pFuncs;
  pOptions->pInterval = pInterval;
  pOptions->pOffset = pOffset;
  pOptions->pSliding = pSliding;
  return (SNode*)pOptions;
}
X
Xiaoyu Wang 已提交
1256

X
Xiaoyu Wang 已提交
1257
SNode* createDropIndexStmt(SAstCreateContext* pCxt, bool ignoreNotExists, SToken* pIndexName, SToken* pTableName) {
X
Xiaoyu Wang 已提交
1258
  CHECK_PARSER_STATUS(pCxt);
1259 1260 1261
  if (!checkIndexName(pCxt, pIndexName) || !checkTableName(pCxt, pTableName)) {
    return NULL;
  }
1262
  SDropIndexStmt* pStmt = (SDropIndexStmt*)nodesMakeNode(QUERY_NODE_DROP_INDEX_STMT);
1263
  CHECK_OUT_OF_MEM(pStmt);
X
Xiaoyu Wang 已提交
1264
  pStmt->ignoreNotExists = ignoreNotExists;
1265 1266
  COPY_STRING_FORM_ID_TOKEN(pStmt->indexName, pIndexName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->tableName, pTableName);
1267 1268 1269
  return (SNode*)pStmt;
}

1270
SNode* createCreateComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId) {
X
Xiaoyu Wang 已提交
1271
  CHECK_PARSER_STATUS(pCxt);
1272
  SCreateComponentNodeStmt* pStmt = (SCreateComponentNodeStmt*)nodesMakeNode(type);
X
Xiaoyu Wang 已提交
1273
  CHECK_OUT_OF_MEM(pStmt);
wafwerar's avatar
wafwerar 已提交
1274
  pStmt->dnodeId = taosStr2Int32(pDnodeId->z, NULL, 10);
X
Xiaoyu Wang 已提交
1275 1276
  return (SNode*)pStmt;
}
1277

1278
SNode* createDropComponentNodeStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pDnodeId) {
X
Xiaoyu Wang 已提交
1279
  CHECK_PARSER_STATUS(pCxt);
1280
  SDropComponentNodeStmt* pStmt = (SDropComponentNodeStmt*)nodesMakeNode(type);
1281
  CHECK_OUT_OF_MEM(pStmt);
wafwerar's avatar
wafwerar 已提交
1282
  pStmt->dnodeId = taosStr2Int32(pDnodeId->z, NULL, 10);
1283 1284 1285
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1286
SNode* createCreateTopicStmt(SAstCreateContext* pCxt, bool ignoreExists, const SToken* pTopicName, SNode* pQuery,
1287
                             const SToken* pSubDbName, SNode* pRealTable) {
X
Xiaoyu Wang 已提交
1288
  CHECK_PARSER_STATUS(pCxt);
1289
  SCreateTopicStmt* pStmt = (SCreateTopicStmt*)nodesMakeNode(QUERY_NODE_CREATE_TOPIC_STMT);
1290
  CHECK_OUT_OF_MEM(pStmt);
1291
  COPY_STRING_FORM_ID_TOKEN(pStmt->topicName, pTopicName);
1292
  pStmt->ignoreExists = ignoreExists;
1293 1294 1295 1296 1297
  if (NULL != pRealTable) {
    strcpy(pStmt->subDbName, ((SRealTableNode*)pRealTable)->table.dbName);
    strcpy(pStmt->subSTbName, ((SRealTableNode*)pRealTable)->table.tableName);
    nodesDestroyNode(pRealTable);
  } else if (NULL != pSubDbName) {
1298
    COPY_STRING_FORM_ID_TOKEN(pStmt->subDbName, pSubDbName);
1299 1300
  } else {
    pStmt->pQuery = pQuery;
1301 1302 1303 1304 1305
  }
  return (SNode*)pStmt;
}

SNode* createDropTopicStmt(SAstCreateContext* pCxt, bool ignoreNotExists, const SToken* pTopicName) {
X
Xiaoyu Wang 已提交
1306
  CHECK_PARSER_STATUS(pCxt);
1307
  SDropTopicStmt* pStmt = (SDropTopicStmt*)nodesMakeNode(QUERY_NODE_DROP_TOPIC_STMT);
1308
  CHECK_OUT_OF_MEM(pStmt);
1309
  COPY_STRING_FORM_ID_TOKEN(pStmt->topicName, pTopicName);
1310 1311 1312
  pStmt->ignoreNotExists = ignoreNotExists;
  return (SNode*)pStmt;
}
1313

X
Xiaoyu Wang 已提交
1314 1315 1316
SNode* createDropCGroupStmt(SAstCreateContext* pCxt, bool ignoreNotExists, const SToken* pCGroupId,
                            const SToken* pTopicName) {
  CHECK_PARSER_STATUS(pCxt);
1317
  SDropCGroupStmt* pStmt = (SDropCGroupStmt*)nodesMakeNode(QUERY_NODE_DROP_CGROUP_STMT);
X
Xiaoyu Wang 已提交
1318 1319
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->ignoreNotExists = ignoreNotExists;
1320 1321
  COPY_STRING_FORM_ID_TOKEN(pStmt->topicName, pTopicName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->cgroup, pCGroupId);
X
Xiaoyu Wang 已提交
1322 1323 1324
  return (SNode*)pStmt;
}

1325
SNode* createAlterLocalStmt(SAstCreateContext* pCxt, const SToken* pConfig, const SToken* pValue) {
X
Xiaoyu Wang 已提交
1326
  CHECK_PARSER_STATUS(pCxt);
1327
  SAlterLocalStmt* pStmt = (SAlterLocalStmt*)nodesMakeNode(QUERY_NODE_ALTER_LOCAL_STMT);
1328 1329 1330 1331 1332 1333 1334
  CHECK_OUT_OF_MEM(pStmt);
  trimString(pConfig->z, pConfig->n, pStmt->config, sizeof(pStmt->config));
  if (NULL != pValue) {
    trimString(pValue->z, pValue->n, pStmt->value, sizeof(pStmt->value));
  }
  return (SNode*)pStmt;
}
1335 1336

SNode* createDefaultExplainOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
1337
  CHECK_PARSER_STATUS(pCxt);
1338
  SExplainOptions* pOptions = (SExplainOptions*)nodesMakeNode(QUERY_NODE_EXPLAIN_OPTIONS);
1339 1340 1341 1342 1343 1344 1345
  CHECK_OUT_OF_MEM(pOptions);
  pOptions->verbose = TSDB_DEFAULT_EXPLAIN_VERBOSE;
  pOptions->ratio = TSDB_DEFAULT_EXPLAIN_RATIO;
  return (SNode*)pOptions;
}

SNode* setExplainVerbose(SAstCreateContext* pCxt, SNode* pOptions, const SToken* pVal) {
X
Xiaoyu Wang 已提交
1346
  CHECK_PARSER_STATUS(pCxt);
1347 1348 1349 1350 1351
  ((SExplainOptions*)pOptions)->verbose = (0 == strncasecmp(pVal->z, "true", pVal->n));
  return pOptions;
}

SNode* setExplainRatio(SAstCreateContext* pCxt, SNode* pOptions, const SToken* pVal) {
X
Xiaoyu Wang 已提交
1352
  CHECK_PARSER_STATUS(pCxt);
wafwerar's avatar
wafwerar 已提交
1353
  ((SExplainOptions*)pOptions)->ratio = taosStr2Double(pVal->z, NULL);
1354 1355 1356 1357
  return pOptions;
}

SNode* createExplainStmt(SAstCreateContext* pCxt, bool analyze, SNode* pOptions, SNode* pQuery) {
X
Xiaoyu Wang 已提交
1358
  CHECK_PARSER_STATUS(pCxt);
1359
  SExplainStmt* pStmt = (SExplainStmt*)nodesMakeNode(QUERY_NODE_EXPLAIN_STMT);
1360 1361 1362 1363 1364 1365
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->analyze = analyze;
  pStmt->pOptions = (SExplainOptions*)pOptions;
  pStmt->pQuery = pQuery;
  return (SNode*)pStmt;
}
1366 1367

SNode* createDescribeStmt(SAstCreateContext* pCxt, SNode* pRealTable) {
X
Xiaoyu Wang 已提交
1368
  CHECK_PARSER_STATUS(pCxt);
1369
  SDescribeStmt* pStmt = (SDescribeStmt*)nodesMakeNode(QUERY_NODE_DESCRIBE_STMT);
1370 1371 1372 1373 1374 1375 1376 1377
  CHECK_OUT_OF_MEM(pStmt);
  strcpy(pStmt->dbName, ((SRealTableNode*)pRealTable)->table.dbName);
  strcpy(pStmt->tableName, ((SRealTableNode*)pRealTable)->table.tableName);
  nodesDestroyNode(pRealTable);
  return (SNode*)pStmt;
}

SNode* createResetQueryCacheStmt(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
1378
  CHECK_PARSER_STATUS(pCxt);
1379 1380 1381 1382
  SNode* pStmt = nodesMakeNode(QUERY_NODE_RESET_QUERY_CACHE_STMT);
  CHECK_OUT_OF_MEM(pStmt);
  return pStmt;
}
1383 1384

SNode* createCompactStmt(SAstCreateContext* pCxt, SNodeList* pVgroups) {
X
Xiaoyu Wang 已提交
1385
  CHECK_PARSER_STATUS(pCxt);
1386 1387 1388 1389 1390
  SNode* pStmt = nodesMakeNode(QUERY_NODE_COMPACT_STMT);
  CHECK_OUT_OF_MEM(pStmt);
  return pStmt;
}

X
Xiaoyu Wang 已提交
1391 1392
SNode* createCreateFunctionStmt(SAstCreateContext* pCxt, bool ignoreExists, bool aggFunc, const SToken* pFuncName,
                                const SToken* pLibPath, SDataType dataType, int32_t bufSize) {
X
Xiaoyu Wang 已提交
1393
  CHECK_PARSER_STATUS(pCxt);
1394
  if (pLibPath->n <= 2) {
1395
    pCxt->errCode = TSDB_CODE_PAR_SYNTAX_ERROR;
1396 1397
    return NULL;
  }
1398
  SCreateFunctionStmt* pStmt = (SCreateFunctionStmt*)nodesMakeNode(QUERY_NODE_CREATE_FUNCTION_STMT);
1399
  CHECK_OUT_OF_MEM(pStmt);
1400
  pStmt->ignoreExists = ignoreExists;
1401
  COPY_STRING_FORM_ID_TOKEN(pStmt->funcName, pFuncName);
1402
  pStmt->isAgg = aggFunc;
1403
  COPY_STRING_FORM_STR_TOKEN(pStmt->libraryPath, pLibPath);
1404 1405 1406
  pStmt->outputDt = dataType;
  pStmt->bufSize = bufSize;
  return (SNode*)pStmt;
1407 1408
}

1409
SNode* createDropFunctionStmt(SAstCreateContext* pCxt, bool ignoreNotExists, const SToken* pFuncName) {
X
Xiaoyu Wang 已提交
1410
  CHECK_PARSER_STATUS(pCxt);
1411
  SDropFunctionStmt* pStmt = (SDropFunctionStmt*)nodesMakeNode(QUERY_NODE_DROP_FUNCTION_STMT);
1412
  CHECK_OUT_OF_MEM(pStmt);
1413
  pStmt->ignoreNotExists = ignoreNotExists;
1414
  COPY_STRING_FORM_ID_TOKEN(pStmt->funcName, pFuncName);
1415
  return (SNode*)pStmt;
1416 1417
}

1418
SNode* createStreamOptions(SAstCreateContext* pCxt) {
X
Xiaoyu Wang 已提交
1419
  CHECK_PARSER_STATUS(pCxt);
1420
  SStreamOptions* pOptions = (SStreamOptions*)nodesMakeNode(QUERY_NODE_STREAM_OPTIONS);
1421 1422 1423 1424 1425
  CHECK_OUT_OF_MEM(pOptions);
  pOptions->triggerType = STREAM_TRIGGER_AT_ONCE;
  return (SNode*)pOptions;
}

X
Xiaoyu Wang 已提交
1426 1427
SNode* createCreateStreamStmt(SAstCreateContext* pCxt, bool ignoreExists, const SToken* pStreamName, SNode* pRealTable,
                              SNode* pOptions, SNode* pQuery) {
X
Xiaoyu Wang 已提交
1428
  CHECK_PARSER_STATUS(pCxt);
1429
  SCreateStreamStmt* pStmt = (SCreateStreamStmt*)nodesMakeNode(QUERY_NODE_CREATE_STREAM_STMT);
1430
  CHECK_OUT_OF_MEM(pStmt);
1431
  COPY_STRING_FORM_ID_TOKEN(pStmt->streamName, pStreamName);
1432 1433 1434 1435 1436 1437 1438 1439 1440
  if (NULL != pRealTable) {
    strcpy(pStmt->targetDbName, ((SRealTableNode*)pRealTable)->table.dbName);
    strcpy(pStmt->targetTabName, ((SRealTableNode*)pRealTable)->table.tableName);
    nodesDestroyNode(pRealTable);
  }
  pStmt->ignoreExists = ignoreExists;
  pStmt->pOptions = (SStreamOptions*)pOptions;
  pStmt->pQuery = pQuery;
  return (SNode*)pStmt;
1441 1442
}

1443
SNode* createDropStreamStmt(SAstCreateContext* pCxt, bool ignoreNotExists, const SToken* pStreamName) {
X
Xiaoyu Wang 已提交
1444
  CHECK_PARSER_STATUS(pCxt);
1445
  SDropStreamStmt* pStmt = (SDropStreamStmt*)nodesMakeNode(QUERY_NODE_DROP_STREAM_STMT);
1446
  CHECK_OUT_OF_MEM(pStmt);
1447
  COPY_STRING_FORM_ID_TOKEN(pStmt->streamName, pStreamName);
1448 1449
  pStmt->ignoreNotExists = ignoreNotExists;
  return (SNode*)pStmt;
1450 1451 1452
}

SNode* createKillStmt(SAstCreateContext* pCxt, ENodeType type, const SToken* pId) {
X
Xiaoyu Wang 已提交
1453
  CHECK_PARSER_STATUS(pCxt);
1454
  SKillStmt* pStmt = (SKillStmt*)nodesMakeNode(type);
1455
  CHECK_OUT_OF_MEM(pStmt);
wafwerar's avatar
wafwerar 已提交
1456
  pStmt->targetId = taosStr2Int32(pId->z, NULL, 10);
1457
  return (SNode*)pStmt;
1458 1459
}

X
Xiaoyu Wang 已提交
1460 1461 1462 1463
SNode* createKillQueryStmt(SAstCreateContext* pCxt, const SToken* pQueryId) {
  CHECK_PARSER_STATUS(pCxt);
  SKillQueryStmt* pStmt = (SKillQueryStmt*)nodesMakeNode(QUERY_NODE_KILL_QUERY_STMT);
  CHECK_OUT_OF_MEM(pStmt);
D
dapan1121 已提交
1464
  trimString(pQueryId->z, pQueryId->n, pStmt->queryId, sizeof(pStmt->queryId) - 1);
X
Xiaoyu Wang 已提交
1465 1466 1467
  return (SNode*)pStmt;
}

X
Xiaoyu Wang 已提交
1468 1469
SNode* createBalanceVgroupStmt(SAstCreateContext* pCxt) {
  CHECK_PARSER_STATUS(pCxt);
1470
  SBalanceVgroupStmt* pStmt = (SBalanceVgroupStmt*)nodesMakeNode(QUERY_NODE_BALANCE_VGROUP_STMT);
X
Xiaoyu Wang 已提交
1471 1472 1473 1474
  CHECK_OUT_OF_MEM(pStmt);
  return (SNode*)pStmt;
}

1475
SNode* createMergeVgroupStmt(SAstCreateContext* pCxt, const SToken* pVgId1, const SToken* pVgId2) {
X
Xiaoyu Wang 已提交
1476
  CHECK_PARSER_STATUS(pCxt);
1477
  SMergeVgroupStmt* pStmt = (SMergeVgroupStmt*)nodesMakeNode(QUERY_NODE_MERGE_VGROUP_STMT);
1478
  CHECK_OUT_OF_MEM(pStmt);
X
Xiaoyu Wang 已提交
1479 1480 1481
  pStmt->vgId1 = taosStr2Int32(pVgId1->z, NULL, 10);
  pStmt->vgId2 = taosStr2Int32(pVgId2->z, NULL, 10);
  return (SNode*)pStmt;
1482 1483 1484
}

SNode* createRedistributeVgroupStmt(SAstCreateContext* pCxt, const SToken* pVgId, SNodeList* pDnodes) {
X
Xiaoyu Wang 已提交
1485
  CHECK_PARSER_STATUS(pCxt);
1486
  SRedistributeVgroupStmt* pStmt = (SRedistributeVgroupStmt*)nodesMakeNode(QUERY_NODE_REDISTRIBUTE_VGROUP_STMT);
1487
  CHECK_OUT_OF_MEM(pStmt);
X
Xiaoyu Wang 已提交
1488 1489 1490
  pStmt->vgId = taosStr2Int32(pVgId->z, NULL, 10);
  pStmt->pDnodes = pDnodes;
  return (SNode*)pStmt;
1491 1492 1493
}

SNode* createSplitVgroupStmt(SAstCreateContext* pCxt, const SToken* pVgId) {
X
Xiaoyu Wang 已提交
1494
  CHECK_PARSER_STATUS(pCxt);
1495
  SSplitVgroupStmt* pStmt = (SSplitVgroupStmt*)nodesMakeNode(QUERY_NODE_SPLIT_VGROUP_STMT);
1496
  CHECK_OUT_OF_MEM(pStmt);
X
Xiaoyu Wang 已提交
1497 1498
  pStmt->vgId = taosStr2Int32(pVgId->z, NULL, 10);
  return (SNode*)pStmt;
1499 1500 1501
}

SNode* createSyncdbStmt(SAstCreateContext* pCxt, const SToken* pDbName) {
X
Xiaoyu Wang 已提交
1502
  CHECK_PARSER_STATUS(pCxt);
1503 1504 1505 1506
  SNode* pStmt = nodesMakeNode(QUERY_NODE_SYNCDB_STMT);
  CHECK_OUT_OF_MEM(pStmt);
  return pStmt;
}
1507 1508

SNode* createGrantStmt(SAstCreateContext* pCxt, int64_t privileges, SToken* pDbName, SToken* pUserName) {
X
Xiaoyu Wang 已提交
1509
  CHECK_PARSER_STATUS(pCxt);
1510 1511 1512
  if (!checkDbName(pCxt, pDbName, false) || !checkUserName(pCxt, pUserName)) {
    return NULL;
  }
1513
  SGrantStmt* pStmt = (SGrantStmt*)nodesMakeNode(QUERY_NODE_GRANT_STMT);
1514 1515
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->privileges = privileges;
1516 1517
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->userName, pUserName);
1518 1519 1520 1521
  return (SNode*)pStmt;
}

SNode* createRevokeStmt(SAstCreateContext* pCxt, int64_t privileges, SToken* pDbName, SToken* pUserName) {
X
Xiaoyu Wang 已提交
1522
  CHECK_PARSER_STATUS(pCxt);
1523 1524 1525
  if (!checkDbName(pCxt, pDbName, false) || !checkUserName(pCxt, pUserName)) {
    return NULL;
  }
1526
  SRevokeStmt* pStmt = (SRevokeStmt*)nodesMakeNode(QUERY_NODE_REVOKE_STMT);
1527 1528
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->privileges = privileges;
1529 1530
  COPY_STRING_FORM_ID_TOKEN(pStmt->dbName, pDbName);
  COPY_STRING_FORM_ID_TOKEN(pStmt->userName, pUserName);
1531 1532
  return (SNode*)pStmt;
}
X
Xiaoyu Wang 已提交
1533

X
Xiaoyu Wang 已提交
1534
SNode* createCountFuncForDelete(SAstCreateContext* pCxt) {
1535
  SFunctionNode* pFunc = (SFunctionNode*)nodesMakeNode(QUERY_NODE_FUNCTION);
X
Xiaoyu Wang 已提交
1536 1537 1538
  CHECK_OUT_OF_MEM(pFunc);
  strcpy(pFunc->functionName, "count");
  if (TSDB_CODE_SUCCESS != nodesListMakeStrictAppend(&pFunc->pParameterList, createPrimaryKeyCol(pCxt))) {
1539
    nodesDestroyNode((SNode*)pFunc);
X
Xiaoyu Wang 已提交
1540 1541 1542 1543 1544
    CHECK_OUT_OF_MEM(NULL);
  }
  return (SNode*)pFunc;
}

X
Xiaoyu Wang 已提交
1545 1546
SNode* createDeleteStmt(SAstCreateContext* pCxt, SNode* pTable, SNode* pWhere) {
  CHECK_PARSER_STATUS(pCxt);
1547
  SDeleteStmt* pStmt = (SDeleteStmt*)nodesMakeNode(QUERY_NODE_DELETE_STMT);
X
Xiaoyu Wang 已提交
1548 1549 1550
  CHECK_OUT_OF_MEM(pStmt);
  pStmt->pFromTable = pTable;
  pStmt->pWhere = pWhere;
X
Xiaoyu Wang 已提交
1551 1552
  pStmt->pCountFunc = createCountFuncForDelete(pCxt);
  if (NULL == pStmt->pCountFunc) {
1553
    nodesDestroyNode((SNode*)pStmt);
X
Xiaoyu Wang 已提交
1554 1555
    CHECK_OUT_OF_MEM(NULL);
  }
X
Xiaoyu Wang 已提交
1556 1557
  return (SNode*)pStmt;
}