clientStmt.h 4.1 KB
Newer Older
D
stmt  
dapan1121 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * 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 TDENGINE_CLIENTSTMT_H
#define TDENGINE_CLIENTSTMT_H

#ifdef __cplusplus
extern "C" {
#endif
D
stmt  
dapan1121 已提交
22 23 24
#include "catalog.h"

typedef void STableDataBlocks;
D
stmt  
dapan1121 已提交
25 26 27 28

typedef enum {
  STMT_TYPE_INSERT = 1,
  STMT_TYPE_MULTI_INSERT,
D
stmt  
dapan1121 已提交
29
  STMT_TYPE_QUERY
D
stmt  
dapan1121 已提交
30 31
} STMT_TYPE;

D
stmt  
dapan1121 已提交
32 33 34 35
typedef enum {
  STMT_INIT = 1,
  STMT_PREPARE,
  STMT_SETTBNAME,
D
stmt  
dapan1121 已提交
36 37
  STMT_FETCH_TAG_FIELDS,
  STMT_FETCH_COL_FIELDS,
D
stmt  
dapan1121 已提交
38 39 40 41 42 43
  STMT_BIND,
  STMT_BIND_COL,
  STMT_ADD_BATCH,
  STMT_EXECUTE
} STMT_STATUS;

D
stmt  
dapan1121 已提交
44 45 46 47 48 49 50 51 52 53 54 55 56 57
typedef struct SStmtTableCache {
  STableDataBlocks* pDataBlock;
  void*             boundTags;
} SStmtTableCache;

typedef struct SStmtBindInfo {
  bool         needParse;
  uint64_t     tbUid;
  uint64_t     tbSuid;
  int8_t       tbType;
  void*        boundTags;  
  char*        tbName;
  SName        sname;
} SStmtBindInfo;
D
stmt  
dapan1121 已提交
58

D
stmt  
dapan1121 已提交
59 60 61 62 63
typedef struct SStmtExecInfo {
  SRequestObj* pRequest;
  SHashObj*    pVgHash;
  SHashObj*    pBlockHash;
} SStmtExecInfo;
D
stmt  
dapan1121 已提交
64

D
stmt  
dapan1121 已提交
65
typedef struct SStmtSQLInfo {
D
stmt  
dapan1121 已提交
66 67
  STMT_TYPE    type;
  STMT_STATUS  status;
D
stmt  
dapan1121 已提交
68 69
  bool         autoCreate;
  uint64_t     runTimes;
D
stmt  
dapan1121 已提交
70
  SHashObj*    pTableCache;   //SHash<SStmtTableCache>
D
stmt  
dapan1121 已提交
71
  SQuery*      pQuery;
D
stmt  
dapan1121 已提交
72
  char*        sqlStr;
D
stmt  
dapan1121 已提交
73
  int32_t      sqlLen;
D
stmt  
dapan1121 已提交
74 75 76 77 78 79 80 81 82
} SStmtSQLInfo;

typedef struct STscStmt {
  STscObj*      taos;
  SCatalog*     pCatalog;

  SStmtSQLInfo  sql;
  SStmtExecInfo exec;
  SStmtBindInfo bind;
D
stmt  
dapan1121 已提交
83 84
} STscStmt;

D
stmt  
dapan1121 已提交
85

D
stmt  
dapan1121 已提交
86 87 88 89
#define STMT_ERR_RET(c) do { int32_t _code = c; if (_code != TSDB_CODE_SUCCESS) { terrno = _code; return _code; } } while (0)
#define STMT_RET(c) do { int32_t _code = c; if (_code != TSDB_CODE_SUCCESS) { terrno = _code; } return _code; } while (0)
#define STMT_ERR_JRET(c) do { code = c; if (code != TSDB_CODE_SUCCESS) { terrno = code; goto _return; } } while (0)

D
stmt  
dapan1121 已提交
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
#define STMT_SWITCH_STATUS(_stmt, _newstatus, _errcode)               \
  do {                                                                \
    switch (_newstatus) {                                             \
      case STMT_INIT:                                                 \
        if ((_stmt)->sql.status != 0) return (_errcode);              \
        break;                                                        \
      case STMT_PREPARE:                                              \
        if ((_stmt)->sql.status != STMT_INIT) STMT_ERR_RET(_errcode); \
        break;                                                        \
      case STMT_SETTBNAME:                                            \
        break;                                                        \
      default:                                                        \
        STMT_ERR_RET(_errcode);                                       \
        break;                                                        \
    }                                                                 \
                                                                      \
    (_stmt)->sql.status = _newstatus;                                 \
  } while (0)
D
stmt  
dapan1121 已提交
108 109


D
stmt  
dapan1121 已提交
110 111 112
TAOS_STMT *stmtInit(TAOS *taos);
int stmtClose(TAOS_STMT *stmt);
int stmtExec(TAOS_STMT *stmt);
D
stmt  
dapan1121 已提交
113
const char *stmtErrstr(TAOS_STMT *stmt);
D
stmt  
dapan1121 已提交
114 115
int stmtAffectedRows(TAOS_STMT *stmt);
int stmtPrepare(TAOS_STMT *stmt, const char *sql, unsigned long length);
D
stmt  
dapan1121 已提交
116 117
int stmtSetTbName(TAOS_STMT *stmt, const char *tbName);
int stmtSetTbTags(TAOS_STMT *stmt, TAOS_BIND_v2 *tags);
D
stmt  
dapan1121 已提交
118 119 120 121
int stmtIsInsert(TAOS_STMT *stmt, int *insert);
int stmtGetParamNum(TAOS_STMT *stmt, int *nums);
int stmtAddBatch(TAOS_STMT *stmt);
TAOS_RES *stmtUseResult(TAOS_STMT *stmt);
D
stmt  
dapan1121 已提交
122
int stmtBindBatch(TAOS_STMT *stmt, TAOS_BIND_v2 *bind);
D
stmt  
dapan1121 已提交
123

D
stmt  
dapan1121 已提交
124 125 126 127 128 129

#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_CLIENTSTMT_H