2021-09-23 07:50:12 +00:00
|
|
|
/*
|
|
|
|
|
* 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_PARSER_INT_H_
|
|
|
|
|
#define _TD_PARSER_INT_H_
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
|
extern "C" {
|
|
|
|
|
#endif
|
|
|
|
|
|
2021-10-06 15:46:48 +00:00
|
|
|
#include "catalog.h"
|
|
|
|
|
#include "tname.h"
|
2021-10-08 02:23:44 +00:00
|
|
|
#include "astGenerator.h"
|
2021-10-06 15:46:48 +00:00
|
|
|
|
2021-10-08 02:23:44 +00:00
|
|
|
struct SSqlNode;
|
2021-10-06 15:46:48 +00:00
|
|
|
|
|
|
|
|
|
2021-10-21 03:06:52 +00:00
|
|
|
typedef struct SInternalField {
|
|
|
|
|
TAOS_FIELD field;
|
|
|
|
|
bool visible;
|
|
|
|
|
SExprInfo *pExpr;
|
|
|
|
|
} SInternalField;
|
|
|
|
|
|
2021-10-23 04:51:29 +00:00
|
|
|
typedef struct SMsgBuf {
|
|
|
|
|
int32_t len;
|
|
|
|
|
char *buf;
|
|
|
|
|
} SMsgBuf;
|
|
|
|
|
|
2021-12-23 02:33:11 +00:00
|
|
|
// create table operation type
|
|
|
|
|
enum TSQL_CREATE_TABLE_TYPE {
|
|
|
|
|
TSQL_CREATE_TABLE = 0x1,
|
|
|
|
|
TSQL_CREATE_STABLE = 0x2,
|
|
|
|
|
TSQL_CREATE_CTABLE = 0x3,
|
|
|
|
|
TSQL_CREATE_STREAM = 0x4,
|
|
|
|
|
};
|
|
|
|
|
|
2021-10-21 03:06:52 +00:00
|
|
|
void clearTableMetaInfo(STableMetaInfo* pTableMetaInfo);
|
|
|
|
|
|
|
|
|
|
void clearAllTableMetaInfo(SQueryStmtInfo* pQueryInfo, bool removeMeta, uint64_t id);
|
|
|
|
|
|
2021-10-06 15:46:48 +00:00
|
|
|
/**
|
2021-10-08 02:23:44 +00:00
|
|
|
* Validate the sql info, according to the corresponding metadata info from catalog.
|
|
|
|
|
* @param pCatalog
|
|
|
|
|
* @param pSqlInfo
|
|
|
|
|
* @param pQueryInfo a bounded AST with essential meta data from local buffer or mgmt node
|
|
|
|
|
* @param id
|
|
|
|
|
* @param msg
|
|
|
|
|
* @return
|
2021-10-06 15:46:48 +00:00
|
|
|
*/
|
2021-10-09 06:01:56 +00:00
|
|
|
int32_t qParserValidateSqlNode(struct SCatalog* pCatalog, SSqlInfo* pSqlInfo, SQueryStmtInfo* pQueryInfo, int64_t id, char* msg, int32_t msgLen);
|
2021-10-06 15:46:48 +00:00
|
|
|
|
2021-12-15 11:34:36 +00:00
|
|
|
/**
|
|
|
|
|
* validate the ddl ast, and convert the ast to the corresponding message format
|
|
|
|
|
* @param pSqlInfo
|
|
|
|
|
* @param output
|
|
|
|
|
* @param type
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
2021-12-23 09:33:41 +00:00
|
|
|
int32_t qParserValidateDclSqlNode(SSqlInfo* pInfo, SParseBasicCtx* pCtx, SDclStmtInfo* pDcl, char* msgBuf, int32_t msgBufLen);
|
2021-12-15 11:34:36 +00:00
|
|
|
|
2021-10-11 07:49:10 +00:00
|
|
|
/**
|
2021-10-12 07:01:05 +00:00
|
|
|
* Evaluate the numeric and timestamp arithmetic expression in the WHERE clause.
|
2021-10-11 07:49:10 +00:00
|
|
|
* @param pNode
|
|
|
|
|
* @param tsPrecision
|
|
|
|
|
* @param msg
|
|
|
|
|
* @param msgBufLen
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
2021-10-23 04:51:29 +00:00
|
|
|
int32_t evaluateSqlNode(SSqlNode* pNode, int32_t tsPrecision, SMsgBuf* pMsgBuf);
|
2021-10-11 07:49:10 +00:00
|
|
|
|
2021-10-26 09:39:37 +00:00
|
|
|
int32_t validateSqlNode(SSqlNode* pSqlNode, SQueryStmtInfo* pQueryInfo, SMsgBuf* pMsgBuf);
|
2021-10-27 09:23:58 +00:00
|
|
|
|
2021-10-28 08:16:42 +00:00
|
|
|
SQueryStmtInfo* createQueryInfo();
|
|
|
|
|
|
|
|
|
|
void destroyQueryInfo(SQueryStmtInfo* pQueryInfo);
|
2021-10-26 09:39:37 +00:00
|
|
|
|
2021-10-27 09:23:58 +00:00
|
|
|
int32_t checkForInvalidExpr(SQueryStmtInfo* pQueryInfo, SMsgBuf* pMsgBuf);
|
|
|
|
|
|
2021-10-06 15:46:48 +00:00
|
|
|
/**
|
2021-10-12 07:01:05 +00:00
|
|
|
* Extract request meta info from the sql statement
|
|
|
|
|
* @param pSqlInfo
|
2021-10-06 15:46:48 +00:00
|
|
|
* @param pMetaInfo
|
2021-10-12 07:01:05 +00:00
|
|
|
* @param msg
|
|
|
|
|
* @param msgBufLen
|
2021-10-06 15:46:48 +00:00
|
|
|
* @return
|
|
|
|
|
*/
|
2021-12-11 03:18:15 +00:00
|
|
|
int32_t qParserExtractRequestedMetaInfo(const SSqlInfo* pSqlInfo, SCatalogReq* pMetaInfo, char* msg, int32_t msgBufLen);
|
2021-10-06 15:46:48 +00:00
|
|
|
|
2021-10-28 08:16:42 +00:00
|
|
|
/**
|
|
|
|
|
* Destroy the meta data request structure.
|
|
|
|
|
* @param pMetaInfo
|
|
|
|
|
*/
|
2021-12-11 03:18:15 +00:00
|
|
|
void qParserClearupMetaRequestInfo(SCatalogReq* pMetaInfo);
|
2021-10-28 08:16:42 +00:00
|
|
|
|
2021-09-23 07:50:12 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif /*_TD_PARSER_INT_H_*/
|