qSqlparser.h 9.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * 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/>.
 */

H
hjxilinx 已提交
16 17
#ifndef TDENGINE_QSQLPARSER_H
#define TDENGINE_QSQLPARSER_H
18 19 20 21 22 23 24 25

#ifdef __cplusplus
extern "C" {
#endif

#include "taos.h"
#include "taosmsg.h"
#include "tstoken.h"
H
Haojun Liao 已提交
26
#include "tstrbuild.h"
27 28
#include "tvariant.h"

H
Haojun Liao 已提交
29
#define ParseTOKENTYPE SStrToken
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
extern char tTokenTypeSwitcher[13];

#define toTSDBType(x)                          \
  do {                                         \
    if ((x) >= tListLen(tTokenTypeSwitcher)) { \
      (x) = TSDB_DATA_TYPE_BINARY;             \
    } else {                                   \
      (x) = tTokenTypeSwitcher[(x)];           \
    }                                          \
  } while (0)

typedef struct SLimitVal {
  int64_t limit;
  int64_t offset;
} SLimitVal;

typedef struct SOrderVal {
  uint32_t order;
H
Haojun Liao 已提交
48
  int32_t  orderColId;
49 50 51 52 53 54 55
} SOrderVal;

typedef struct tVariantListItem {
  tVariant pVar;
  uint8_t  sortOrder;
} tVariantListItem;

56 57 58 59 60
typedef struct SIntervalVal {
  SStrToken interval;
  SStrToken offset;
} SIntervalVal;

61 62
typedef struct SQuerySQL {
  struct tSQLExprList *pSelection;   // select clause
H
Haojun Liao 已提交
63
  SArray *             from;         // from clause  SArray<tVariantListItem>
64
  struct tSQLExpr *    pWhere;       // where clause [optional]
H
Haojun Liao 已提交
65 66
  SArray *             pGroupby;     // groupby clause, only for tags[optional], SArray<tVariantListItem>
  SArray *             pSortOrder;   // orderby [optional], SArray<tVariantListItem>
H
Haojun Liao 已提交
67
  SStrToken            interval;     // interval [optional]
68
  SStrToken            offset;       // offset window [optional]
H
Haojun Liao 已提交
69
  SStrToken            sliding;      // sliding window [optional]
70 71
  SLimitVal            limit;        // limit offset [optional]
  SLimitVal            slimit;       // group limit offset [optional]
H
Haojun Liao 已提交
72
  SArray *             fillType;     // fill type[optional], SArray<tVariantListItem>
H
Haojun Liao 已提交
73
  SStrToken            selectToken;  // sql string
74 75
} SQuerySQL;

76 77 78 79 80 81 82 83 84
typedef struct SCreatedTableInfo {
  SStrToken  name;        // table name token
  SStrToken  stableName;  // super table name token , for using clause
  SArray    *pTagVals;    // create by using super table, tag value
  char      *fullname;    // table full name
  STagData   tagdata;     // true tag data, super table full name is in STagData
  int8_t     igExist;     // ignore if exists
} SCreatedTableInfo;

85
typedef struct SCreateTableSQL {
86 87 88 89
  SStrToken    name;  // table name, create table [name] xxx
  int8_t       type;  // create normal table/from super table/ stream
  bool         existCheck;

90
  struct {
91 92
    SArray    *pTagColumns; // SArray<TAOS_FIELD>
    SArray    *pColumns;    // SArray<TAOS_FIELD>
93
  } colInfo;
94 95 96

  SArray      *childTableInfo;        // SArray<SCreatedTableInfo>
  SQuerySQL   *pSelect;
97 98
} SCreateTableSQL;

H
Haojun Liao 已提交
99
typedef struct SAlterTableInfo {
H
Haojun Liao 已提交
100
  SStrToken     name;
D
dapan1121 已提交
101
  int16_t       tableType;
102 103
  int16_t       type;
  STagData      tagData;
H
Haojun Liao 已提交
104 105
  SArray       *pAddColumns; // SArray<TAOS_FIELD>
  SArray       *varList;  // set t=val or: change src dst, SArray<tVariantListItem>
H
Haojun Liao 已提交
106
} SAlterTableInfo;
107

H
Haojun Liao 已提交
108
typedef struct SCreateDbInfo {
H
Haojun Liao 已提交
109
  SStrToken dbname;
110 111
  int32_t   replica;
  int32_t   cacheBlockSize;
H
hjxilinx 已提交
112 113
  int32_t   maxTablesPerVnode;
  int32_t   numOfBlocks;
114
  int32_t   daysPerFile;
H
hjxilinx 已提交
115 116
  int32_t   minRowsPerBlock;
  int32_t   maxRowsPerBlock;
陶建辉(Jeff)'s avatar
陶建辉(Jeff) 已提交
117
  int32_t   fsyncPeriod;
118
  int64_t   commitTime;
H
hjxilinx 已提交
119
  int32_t   walLevel;
120
  int32_t   quorum;
121
  int32_t   compressionLevel;
H
Haojun Liao 已提交
122
  SStrToken precision;
123
  bool      ignoreExists;
D
dapan1121 已提交
124 125
  int8_t    update;
  int8_t    cachelast; 
H
Haojun Liao 已提交
126 127
  SArray    *keep;
} SCreateDbInfo;
128

H
Haojun Liao 已提交
129
typedef struct SCreateAcctInfo {
130 131 132 133 134 135 136 137
  int32_t   maxUsers;
  int32_t   maxDbs;
  int32_t   maxTimeSeries;
  int32_t   maxStreams;
  int32_t   maxPointsPerSecond;
  int64_t   maxStorage;
  int64_t   maxQueryTime;
  int32_t   maxConnections;
H
Haojun Liao 已提交
138
  SStrToken stat;
H
Haojun Liao 已提交
139
} SCreateAcctInfo;
140 141 142

typedef struct SShowInfo {
  uint8_t showType;
H
Haojun Liao 已提交
143 144
  SStrToken prefix;
  SStrToken pattern;
145 146 147
} SShowInfo;

typedef struct SUserInfo {
H
Haojun Liao 已提交
148 149 150
  SStrToken user;
  SStrToken passwd;
  SStrToken privilege;
151 152 153
  int16_t   type;
} SUserInfo;

H
Haojun Liao 已提交
154 155 156
typedef struct SMiscInfo {
  SArray    *a;         // SArray<SStrToken>
  bool       existsCheck;
D
dapan1121 已提交
157
  int16_t    tableType;
H
Haojun Liao 已提交
158
  SUserInfo  user;
159
  union {
H
Haojun Liao 已提交
160 161 162 163
    SCreateDbInfo   dbOpt;
    SCreateAcctInfo acctOpt;
    SShowInfo       showOpt;
    SStrToken       id;
164
  };
H
Haojun Liao 已提交
165
} SMiscInfo;
166 167 168 169 170 171 172

typedef struct SSubclauseInfo {  // "UNION" multiple select sub-clause
  SQuerySQL **pClause;
  int32_t     numOfClause;
} SSubclauseInfo;

typedef struct SSqlInfo {
H
Haojun Liao 已提交
173 174
  int32_t            type;
  bool               valid;
H
Haojun Liao 已提交
175 176
  SSubclauseInfo     subclauseInfo;
  char               msg[256];
177
  union {
H
Haojun Liao 已提交
178 179 180
    SCreateTableSQL  *pCreateTableInfo;
    SAlterTableInfo  *pAlterInfo;
    SMiscInfo        *pMiscInfo;
181 182 183 184
  };
} SSqlInfo;

typedef struct tSQLExpr {
H
Haojun Liao 已提交
185
  uint32_t         nSQLOptr;    // TK_FUNCTION: sql function, TK_LE: less than(binary expr)
186 187 188
  
  // the full sql string of function(col, param), which is actually the raw
  // field name, since the function name is kept in nSQLOptr already
H
Haojun Liao 已提交
189 190 191 192 193
  SStrToken        operand;
  SStrToken        colInfo;     // field id
  tVariant         val;         // value only for string, float, int
  SStrToken        token;       // original sql expr string

H
[td-32]  
hjxilinx 已提交
194 195 196
  struct tSQLExpr *pLeft;       // left child
  struct tSQLExpr *pRight;      // right child
  struct tSQLExprList *pParam;  // function parameters
197 198 199
} tSQLExpr;

// used in select clause. select <tSQLExprList> from xxx
H
Haojun Liao 已提交
200
typedef struct tSqlExprItem {
201 202
  tSQLExpr *pNode;      // The list of expressions
  char *    aliasName;  // alias name, null-terminated string
dengyihao's avatar
TD-2571  
dengyihao 已提交
203
  bool      distinct;
H
Haojun Liao 已提交
204
} tSqlExprItem;
205

206
// todo refactor by using SArray
207 208 209
typedef struct tSQLExprList {
  int32_t       nExpr;  /* Number of expressions on the list */
  int32_t       nAlloc; /* Number of entries allocated below */
H
Haojun Liao 已提交
210
  tSqlExprItem *a;      /* One entry for each expression */
211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227
} tSQLExprList;

/**
 *
 * @param yyp      The parser
 * @param yymajor  The major token code number
 * @param yyminor  The value for the token
 */
void Parse(void *yyp, int yymajor, ParseTOKENTYPE yyminor, SSqlInfo *);

/**
 *
 * @param p         The parser to be deleted
 * @param freeProc  Function used to reclaim memory
 */
void ParseFree(void *p, void (*freeProc)(void *));

H
Haojun Liao 已提交
228 229 230
SArray *tVariantListAppend(SArray *pList, tVariant *pVar, uint8_t sortOrder);
SArray *tVariantListInsert(SArray *pList, tVariant *pVar, uint8_t sortOrder, int32_t index);
SArray *tVariantListAppendToken(SArray *pList, SStrToken *pAliasToken, uint8_t sortOrder);
231

H
Haojun Liao 已提交
232
tSQLExpr *tSqlExprCreate(tSQLExpr *pLeft, tSQLExpr *pRight, int32_t optrType);
233

H
Haojun Liao 已提交
234
void tSqlExprDestroy(tSQLExpr *pExpr);
235

dengyihao's avatar
TD-2571  
dengyihao 已提交
236
tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken *pDistinct, SStrToken *pToken);
237

H
Haojun Liao 已提交
238
void tSqlExprListDestroy(tSQLExprList *pList);
239

H
Haojun Liao 已提交
240
SQuerySQL *tSetQuerySqlElems(SStrToken *pSelectToken, tSQLExprList *pSelection, SArray *pFrom, tSQLExpr *pWhere,
H
Haojun Liao 已提交
241 242
                             SArray *pGroupby, SArray *pSortOrder, SIntervalVal *pInterval,
                             SStrToken *pSliding, SArray *pFill, SLimitVal *pLimit, SLimitVal *pGLimit);
243

H
Haojun Liao 已提交
244
SCreateTableSQL *tSetCreateSqlElems(SArray *pCols, SArray *pTags, SQuerySQL *pSelect, int32_t type);
245

H
Haojun Liao 已提交
246
void tSqlExprNodeDestroy(tSQLExpr *pExpr);
247

H
Haojun Liao 已提交
248
SAlterTableInfo *  tAlterTableSqlElems(SStrToken *pTableName, SArray *pCols, SArray *pVals, int32_t type, int16_t tableTable);
249
SCreatedTableInfo createNewChildTableInfo(SStrToken *pTableName, SArray *pTagVals, SStrToken *pToken, SStrToken* igExists);
250 251 252

void destroyAllSelectClause(SSubclauseInfo *pSql);
void doDestroyQuerySql(SQuerySQL *pSql);
253
void freeCreateTableInfo(void* p);
254

H
Haojun Liao 已提交
255
SSqlInfo       *      setSqlInfo(SSqlInfo *pInfo, void *pSqlExprInfo, SStrToken *pTableName, int32_t type);
256 257 258 259
SSubclauseInfo *setSubclause(SSubclauseInfo *pClause, void *pSqlExprInfo);

SSubclauseInfo *appendSelectClause(SSubclauseInfo *pInfo, void *pSubclause);

260
void setCreatedTableName(SSqlInfo *pInfo, SStrToken *pTableNameToken, SStrToken *pIfNotExists);
261

H
Haojun Liao 已提交
262
void SqlInfoDestroy(SSqlInfo *pInfo);
263 264

void setDCLSQLElems(SSqlInfo *pInfo, int32_t type, int32_t nParams, ...);
D
dapan1121 已提交
265
void setDropDbTableInfo(SSqlInfo *pInfo, int32_t type, SStrToken* pToken, SStrToken* existsCheck,int16_t tableType);
H
Haojun Liao 已提交
266
void setShowOptions(SSqlInfo *pInfo, int32_t type, SStrToken* prefix, SStrToken* pPatterns);
267

H
Haojun Liao 已提交
268
void setCreateDbInfo(SSqlInfo *pInfo, int32_t type, SStrToken *pToken, SCreateDbInfo *pDB, SStrToken *pIgExists);
269

H
Haojun Liao 已提交
270
void setCreateAcctSql(SSqlInfo *pInfo, int32_t type, SStrToken *pName, SStrToken *pPwd, SCreateAcctInfo *pAcctInfo);
H
Haojun Liao 已提交
271 272 273
void setCreateUserSql(SSqlInfo *pInfo, SStrToken *pName, SStrToken *pPasswd);
void setKillSql(SSqlInfo *pInfo, int32_t type, SStrToken *ip);
void setAlterUserSql(SSqlInfo *pInfo, int16_t type, SStrToken *pName, SStrToken* pPwd, SStrToken *pPrivilege);
274

H
Haojun Liao 已提交
275
void setDefaultCreateDbOption(SCreateDbInfo *pDBInfo);
276 277

// prefix show db.tables;
H
Haojun Liao 已提交
278
void setDbName(SStrToken *pCpxName, SStrToken *pDb);
279

H
Haojun Liao 已提交
280
tSQLExpr *tSqlExprIdValueCreate(SStrToken *pToken, int32_t optrType);
281

H
Haojun Liao 已提交
282
tSQLExpr *tSqlExprCreateFunction(tSQLExprList *pList, SStrToken *pFuncToken, SStrToken *endToken, int32_t optType);
283

H
Haojun Liao 已提交
284
void tSqlSetColumnInfo(TAOS_FIELD *pField, SStrToken *pName, TAOS_FIELD *pType);
285

H
Haojun Liao 已提交
286
void tSqlSetColumnType(TAOS_FIELD *pField, SStrToken *type);
287 288 289

void *ParseAlloc(void *(*mallocProc)(size_t));

290
enum {
H
[td-32]  
hjxilinx 已提交
291 292
  TSQL_NODE_TYPE_EXPR  = 0x1,
  TSQL_NODE_TYPE_ID    = 0x2,
293 294 295 296
  TSQL_NODE_TYPE_VALUE = 0x4,
};

#define NON_ARITHMEIC_EXPR 0
H
[td-32]  
hjxilinx 已提交
297 298
#define NORMAL_ARITHMETIC  1
#define AGG_ARIGHTMEIC     2
299

300
SSqlInfo qSQLParse(const char *str);
301

302 303 304 305
#ifdef __cplusplus
}
#endif

H
hjxilinx 已提交
306
#endif  // TDENGINE_QSQLPARSER_H