Merge pull request #12201 from taosdata/feature/qnode
fix: fix filter issue
This commit is contained in:
commit
887b1ebf77
|
@ -89,7 +89,7 @@ extern char *qtypeStr[];
|
||||||
|
|
||||||
#define TSDB_PORT_HTTP 11
|
#define TSDB_PORT_HTTP 11
|
||||||
|
|
||||||
#undef TD_DEBUG_PRINT_ROW
|
#define TD_DEBUG_PRINT_ROW
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -184,7 +184,7 @@ extern int32_t (*queryProcessMsgRsp[TDMT_MAX])(void* output, char* msg, int32_t
|
||||||
#define SET_META_TYPE_TABLE(t) (t) = META_TYPE_TABLE
|
#define SET_META_TYPE_TABLE(t) (t) = META_TYPE_TABLE
|
||||||
#define SET_META_TYPE_BOTH_TABLE(t) (t) = META_TYPE_BOTH_TABLE
|
#define SET_META_TYPE_BOTH_TABLE(t) (t) = META_TYPE_BOTH_TABLE
|
||||||
|
|
||||||
#define NEED_CLIENT_RM_TBLMETA_ERROR(_code) ((_code) == TSDB_CODE_TDB_INVALID_TABLE_ID || (_code) == TSDB_CODE_VND_TB_NOT_EXIST)
|
#define NEED_CLIENT_RM_TBLMETA_ERROR(_code) ((_code) == TSDB_CODE_PAR_TABLE_NOT_EXIST || (_code) == TSDB_CODE_VND_TB_NOT_EXIST)
|
||||||
#define NEED_CLIENT_REFRESH_VG_ERROR(_code) ((_code) == TSDB_CODE_VND_HASH_MISMATCH || (_code) == TSDB_CODE_VND_INVALID_VGROUP_ID)
|
#define NEED_CLIENT_REFRESH_VG_ERROR(_code) ((_code) == TSDB_CODE_VND_HASH_MISMATCH || (_code) == TSDB_CODE_VND_INVALID_VGROUP_ID)
|
||||||
#define NEED_CLIENT_REFRESH_TBLMETA_ERROR(_code) ((_code) == TSDB_CODE_TDB_TABLE_RECREATED)
|
#define NEED_CLIENT_REFRESH_TBLMETA_ERROR(_code) ((_code) == TSDB_CODE_TDB_TABLE_RECREATED)
|
||||||
#define NEED_CLIENT_HANDLE_ERROR(_code) (NEED_CLIENT_RM_TBLMETA_ERROR(_code) || NEED_CLIENT_REFRESH_VG_ERROR(_code) || NEED_CLIENT_REFRESH_TBLMETA_ERROR(_code))
|
#define NEED_CLIENT_HANDLE_ERROR(_code) (NEED_CLIENT_RM_TBLMETA_ERROR(_code) || NEED_CLIENT_REFRESH_VG_ERROR(_code) || NEED_CLIENT_REFRESH_TBLMETA_ERROR(_code))
|
||||||
|
|
|
@ -88,6 +88,7 @@ int32_t* taosGetErrno();
|
||||||
#define TSDB_CODE_CFG_NOT_FOUND TAOS_DEF_ERROR_CODE(0, 0x0114)
|
#define TSDB_CODE_CFG_NOT_FOUND TAOS_DEF_ERROR_CODE(0, 0x0114)
|
||||||
#define TSDB_CODE_REPEAT_INIT TAOS_DEF_ERROR_CODE(0, 0x0115)
|
#define TSDB_CODE_REPEAT_INIT TAOS_DEF_ERROR_CODE(0, 0x0115)
|
||||||
#define TSDB_CODE_DUP_KEY TAOS_DEF_ERROR_CODE(0, 0x0116)
|
#define TSDB_CODE_DUP_KEY TAOS_DEF_ERROR_CODE(0, 0x0116)
|
||||||
|
#define TSDB_CODE_NEED_RETRY TAOS_DEF_ERROR_CODE(0, 0x0117)
|
||||||
|
|
||||||
#define TSDB_CODE_REF_NO_MEMORY TAOS_DEF_ERROR_CODE(0, 0x0140)
|
#define TSDB_CODE_REF_NO_MEMORY TAOS_DEF_ERROR_CODE(0, 0x0140)
|
||||||
#define TSDB_CODE_REF_FULL TAOS_DEF_ERROR_CODE(0, 0x0141)
|
#define TSDB_CODE_REF_FULL TAOS_DEF_ERROR_CODE(0, 0x0141)
|
||||||
|
|
|
@ -310,6 +310,7 @@ void hbMgrInitMqHbRspHandle();
|
||||||
SRequestObj* launchQueryImpl(SRequestObj* pRequest, SQuery* pQuery, int32_t code, bool keepQuery);
|
SRequestObj* launchQueryImpl(SRequestObj* pRequest, SQuery* pQuery, int32_t code, bool keepQuery);
|
||||||
int32_t getQueryPlan(SRequestObj* pRequest, SQuery* pQuery, SArray** pNodeList);
|
int32_t getQueryPlan(SRequestObj* pRequest, SQuery* pQuery, SArray** pNodeList);
|
||||||
int32_t scheduleQuery(SRequestObj* pRequest, SQueryPlan* pDag, SArray* pNodeList);
|
int32_t scheduleQuery(SRequestObj* pRequest, SQueryPlan* pDag, SArray* pNodeList);
|
||||||
|
int32_t refreshMeta(STscObj* pTscObj, SRequestObj* pRequest);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,7 @@ typedef struct SStmtBindInfo {
|
||||||
int32_t sBindRowNum;
|
int32_t sBindRowNum;
|
||||||
int32_t sBindLastIdx;
|
int32_t sBindLastIdx;
|
||||||
int8_t tbType;
|
int8_t tbType;
|
||||||
|
bool tagsCached;
|
||||||
void* boundTags;
|
void* boundTags;
|
||||||
char* tbName;
|
char* tbName;
|
||||||
SName sname;
|
SName sname;
|
||||||
|
|
|
@ -405,7 +405,7 @@ static int32_t smlModifyDBSchemas(SSmlHandle* info) {
|
||||||
|
|
||||||
code = catalogGetSTableMeta(info->pCatalog, info->taos->pAppInfo->pTransporter, &ep, &pName, &pTableMeta);
|
code = catalogGetSTableMeta(info->pCatalog, info->taos->pAppInfo->pTransporter, &ep, &pName, &pTableMeta);
|
||||||
|
|
||||||
if (code == TSDB_CODE_TDB_INVALID_TABLE_ID || code == TSDB_CODE_MND_INVALID_STB) {
|
if (code == TSDB_CODE_PAR_TABLE_NOT_EXIST || code == TSDB_CODE_MND_INVALID_STB) {
|
||||||
SSchemaAction schemaAction = {0};
|
SSchemaAction schemaAction = {0};
|
||||||
schemaAction.action = SCHEMA_ACTION_CREATE_STABLE;
|
schemaAction.action = SCHEMA_ACTION_CREATE_STABLE;
|
||||||
memcpy(schemaAction.createSTable.sTableName, superTable, superTableLen);
|
memcpy(schemaAction.createSTable.sTableName, superTable, superTableLen);
|
||||||
|
|
|
@ -29,6 +29,11 @@ int32_t stmtSwitchStatus(STscStmt* pStmt, STMT_STATUS newStatus) {
|
||||||
if (STMT_STATUS_EQ(INIT) || STMT_STATUS_EQ(BIND_COL)) {
|
if (STMT_STATUS_EQ(INIT) || STMT_STATUS_EQ(BIND_COL)) {
|
||||||
code = TSDB_CODE_TSC_STMT_API_ERROR;
|
code = TSDB_CODE_TSC_STMT_API_ERROR;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
if ((pStmt->sql.type == STMT_TYPE_MULTI_INSERT) && ()) {
|
||||||
|
code = TSDB_CODE_TSC_STMT_API_ERROR;
|
||||||
|
}
|
||||||
|
*/
|
||||||
break;
|
break;
|
||||||
case STMT_BIND_COL:
|
case STMT_BIND_COL:
|
||||||
if (STMT_STATUS_EQ(INIT) || STMT_STATUS_EQ(BIND)) {
|
if (STMT_STATUS_EQ(INIT) || STMT_STATUS_EQ(BIND)) {
|
||||||
|
@ -123,6 +128,7 @@ int32_t stmtSetBindInfo(TAOS_STMT* stmt, STableMeta* pTableMeta, void* tags) {
|
||||||
pStmt->bInfo.tbSuid = pTableMeta->suid;
|
pStmt->bInfo.tbSuid = pTableMeta->suid;
|
||||||
pStmt->bInfo.tbType = pTableMeta->tableType;
|
pStmt->bInfo.tbType = pTableMeta->tableType;
|
||||||
pStmt->bInfo.boundTags = tags;
|
pStmt->bInfo.boundTags = tags;
|
||||||
|
pStmt->bInfo.tagsCached = false;
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -207,8 +213,6 @@ int32_t stmtParseSql(STscStmt* pStmt) {
|
||||||
STMT_ERR_RET(TSDB_CODE_TSC_STMT_CLAUSE_ERROR);
|
STMT_ERR_RET(TSDB_CODE_TSC_STMT_CLAUSE_ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
STMT_ERR_RET(stmtCacheBlock(pStmt));
|
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -219,8 +223,10 @@ int32_t stmtCleanBindInfo(STscStmt* pStmt) {
|
||||||
pStmt->bInfo.needParse = true;
|
pStmt->bInfo.needParse = true;
|
||||||
|
|
||||||
taosMemoryFreeClear(pStmt->bInfo.tbName);
|
taosMemoryFreeClear(pStmt->bInfo.tbName);
|
||||||
|
if (!pStmt->bInfo.tagsCached) {
|
||||||
destroyBoundColumnInfo(pStmt->bInfo.boundTags);
|
destroyBoundColumnInfo(pStmt->bInfo.boundTags);
|
||||||
taosMemoryFreeClear(pStmt->bInfo.boundTags);
|
taosMemoryFreeClear(pStmt->bInfo.boundTags);
|
||||||
|
}
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -275,6 +281,7 @@ int32_t stmtCleanSQLInfo(STscStmt* pStmt) {
|
||||||
|
|
||||||
qDestroyStmtDataBlock(pCache->pDataBlock);
|
qDestroyStmtDataBlock(pCache->pDataBlock);
|
||||||
destroyBoundColumnInfo(pCache->boundTags);
|
destroyBoundColumnInfo(pCache->boundTags);
|
||||||
|
taosMemoryFreeClear(pCache->boundTags);
|
||||||
|
|
||||||
pIter = taosHashIterate(pStmt->sql.pTableCache, pIter);
|
pIter = taosHashIterate(pStmt->sql.pTableCache, pIter);
|
||||||
}
|
}
|
||||||
|
@ -302,7 +309,15 @@ int32_t stmtGetFromCache(STscStmt* pStmt) {
|
||||||
|
|
||||||
STableMeta *pTableMeta = NULL;
|
STableMeta *pTableMeta = NULL;
|
||||||
SEpSet ep = getEpSet_s(&pStmt->taos->pAppInfo->mgmtEp);
|
SEpSet ep = getEpSet_s(&pStmt->taos->pAppInfo->mgmtEp);
|
||||||
STMT_ERR_RET(catalogGetTableMeta(pStmt->pCatalog, pStmt->taos->pAppInfo->pTransporter, &ep, &pStmt->bInfo.sname, &pTableMeta));
|
int32_t code = catalogGetTableMeta(pStmt->pCatalog, pStmt->taos->pAppInfo->pTransporter, &ep, &pStmt->bInfo.sname, &pTableMeta);
|
||||||
|
if (TSDB_CODE_PAR_TABLE_NOT_EXIST == code) {
|
||||||
|
STMT_ERR_RET(stmtCleanBindInfo(pStmt));
|
||||||
|
|
||||||
|
return TSDB_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
STMT_ERR_RET(code);
|
||||||
|
|
||||||
uint64_t uid = pTableMeta->uid;
|
uint64_t uid = pTableMeta->uid;
|
||||||
uint64_t suid = pTableMeta->suid;
|
uint64_t suid = pTableMeta->suid;
|
||||||
int8_t tableType = pTableMeta->tableType;
|
int8_t tableType = pTableMeta->tableType;
|
||||||
|
@ -328,6 +343,7 @@ int32_t stmtGetFromCache(STscStmt* pStmt) {
|
||||||
pStmt->bInfo.tbSuid = suid;
|
pStmt->bInfo.tbSuid = suid;
|
||||||
pStmt->bInfo.tbType = tableType;
|
pStmt->bInfo.tbType = tableType;
|
||||||
pStmt->bInfo.boundTags = pCache->boundTags;
|
pStmt->bInfo.boundTags = pCache->boundTags;
|
||||||
|
pStmt->bInfo.tagsCached = true;
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -340,6 +356,7 @@ int32_t stmtGetFromCache(STscStmt* pStmt) {
|
||||||
pStmt->bInfo.tbSuid = suid;
|
pStmt->bInfo.tbSuid = suid;
|
||||||
pStmt->bInfo.tbType = tableType;
|
pStmt->bInfo.tbType = tableType;
|
||||||
pStmt->bInfo.boundTags = pCache->boundTags;
|
pStmt->bInfo.boundTags = pCache->boundTags;
|
||||||
|
pStmt->bInfo.tagsCached = true;
|
||||||
|
|
||||||
STableDataBlocks* pNewBlock = NULL;
|
STableDataBlocks* pNewBlock = NULL;
|
||||||
STMT_ERR_RET(qRebuildStmtDataBlock(&pNewBlock, pCache->pDataBlock));
|
STMT_ERR_RET(qRebuildStmtDataBlock(&pNewBlock, pCache->pDataBlock));
|
||||||
|
@ -448,10 +465,12 @@ int stmtSetTbTags(TAOS_STMT *stmt, TAOS_MULTI_BIND *tags) {
|
||||||
|
|
||||||
STMT_ERR_RET(stmtSwitchStatus(pStmt, STMT_SETTAGS));
|
STMT_ERR_RET(stmtSwitchStatus(pStmt, STMT_SETTAGS));
|
||||||
|
|
||||||
if (pStmt->bInfo.needParse) {
|
if (!pStmt->bInfo.needParse) {
|
||||||
STMT_ERR_RET(stmtParseSql(pStmt));
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
STMT_ERR_RET(stmtParseSql(pStmt));
|
||||||
|
|
||||||
STableDataBlocks **pDataBlock = (STableDataBlocks**)taosHashGet(pStmt->exec.pBlockHash, (const char*)&pStmt->bInfo.tbUid, sizeof(pStmt->bInfo.tbUid));
|
STableDataBlocks **pDataBlock = (STableDataBlocks**)taosHashGet(pStmt->exec.pBlockHash, (const char*)&pStmt->bInfo.tbUid, sizeof(pStmt->bInfo.tbUid));
|
||||||
if (NULL == pDataBlock) {
|
if (NULL == pDataBlock) {
|
||||||
tscError("table uid %" PRIx64 "not found in exec blockHash", pStmt->bInfo.tbUid);
|
tscError("table uid %" PRIx64 "not found in exec blockHash", pStmt->bInfo.tbUid);
|
||||||
|
@ -501,8 +520,6 @@ int32_t stmtFetchColFields(STscStmt* pStmt, int32_t *fieldNum, TAOS_FIELD** fiel
|
||||||
int stmtBindBatch(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind, int32_t colIdx) {
|
int stmtBindBatch(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind, int32_t colIdx) {
|
||||||
STscStmt* pStmt = (STscStmt*)stmt;
|
STscStmt* pStmt = (STscStmt*)stmt;
|
||||||
|
|
||||||
STMT_ERR_RET(stmtSwitchStatus(pStmt, STMT_BIND));
|
|
||||||
|
|
||||||
if (pStmt->bInfo.needParse && pStmt->sql.runTimes && pStmt->sql.type > 0 && STMT_TYPE_MULTI_INSERT != pStmt->sql.type) {
|
if (pStmt->bInfo.needParse && pStmt->sql.runTimes && pStmt->sql.type > 0 && STMT_TYPE_MULTI_INSERT != pStmt->sql.type) {
|
||||||
pStmt->bInfo.needParse = false;
|
pStmt->bInfo.needParse = false;
|
||||||
}
|
}
|
||||||
|
@ -520,6 +537,8 @@ int stmtBindBatch(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind, int32_t colIdx) {
|
||||||
STMT_ERR_RET(stmtParseSql(pStmt));
|
STMT_ERR_RET(stmtParseSql(pStmt));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
STMT_ERR_RET(stmtSwitchStatus(pStmt, STMT_BIND));
|
||||||
|
|
||||||
if (STMT_TYPE_QUERY == pStmt->sql.type) {
|
if (STMT_TYPE_QUERY == pStmt->sql.type) {
|
||||||
if (NULL == pStmt->sql.pQueryPlan) {
|
if (NULL == pStmt->sql.pQueryPlan) {
|
||||||
STMT_ERR_RET(getQueryPlan(pStmt->exec.pRequest, pStmt->sql.pQuery, &pStmt->sql.nodeList));
|
STMT_ERR_RET(getQueryPlan(pStmt->exec.pRequest, pStmt->sql.pQuery, &pStmt->sql.nodeList));
|
||||||
|
@ -587,6 +606,16 @@ int stmtExec(TAOS_STMT *stmt) {
|
||||||
launchQueryImpl(pStmt->exec.pRequest, pStmt->sql.pQuery, TSDB_CODE_SUCCESS, true);
|
launchQueryImpl(pStmt->exec.pRequest, pStmt->sql.pQuery, TSDB_CODE_SUCCESS, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (pStmt->exec.pRequest->code && NEED_CLIENT_HANDLE_ERROR(pStmt->exec.pRequest->code)) {
|
||||||
|
code = refreshMeta(pStmt->exec.pRequest->pTscObj, pStmt->exec.pRequest);
|
||||||
|
if (code) {
|
||||||
|
pStmt->exec.pRequest->code = code;
|
||||||
|
} else {
|
||||||
|
STMT_ERR_RET(stmtResetStmt(pStmt));
|
||||||
|
STMT_ERR_RET(TSDB_CODE_NEED_RETRY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
STMT_ERR_JRET(pStmt->exec.pRequest->code);
|
STMT_ERR_JRET(pStmt->exec.pRequest->code);
|
||||||
|
|
||||||
pStmt->exec.affectedRows = taos_affected_rows(pStmt->exec.pRequest);
|
pStmt->exec.affectedRows = taos_affected_rows(pStmt->exec.pRequest);
|
||||||
|
@ -613,13 +642,11 @@ int stmtClose(TAOS_STMT *stmt) {
|
||||||
const char *stmtErrstr(TAOS_STMT *stmt) {
|
const char *stmtErrstr(TAOS_STMT *stmt) {
|
||||||
STscStmt* pStmt = (STscStmt*)stmt;
|
STscStmt* pStmt = (STscStmt*)stmt;
|
||||||
|
|
||||||
if (stmt == NULL) {
|
if (stmt == NULL || NULL == pStmt->exec.pRequest) {
|
||||||
return (char*) tstrerror(terrno);
|
return (char*) tstrerror(terrno);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pStmt->exec.pRequest) {
|
|
||||||
pStmt->exec.pRequest->code = terrno;
|
pStmt->exec.pRequest->code = terrno;
|
||||||
}
|
|
||||||
|
|
||||||
return taos_errstr(pStmt->exec.pRequest);
|
return taos_errstr(pStmt->exec.pRequest);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1233,21 +1233,21 @@ int32_t tDeserializeSGetUserAuthRspImpl(SDecoder *pDecoder, SGetUserAuthRsp *pRs
|
||||||
for (int32_t i = 0; i < numOfCreatedDbs; ++i) {
|
for (int32_t i = 0; i < numOfCreatedDbs; ++i) {
|
||||||
char db[TSDB_DB_FNAME_LEN] = {0};
|
char db[TSDB_DB_FNAME_LEN] = {0};
|
||||||
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
||||||
int32_t len = strlen(db) + 1;
|
int32_t len = strlen(db);
|
||||||
taosHashPut(pRsp->createdDbs, db, len, db, len);
|
taosHashPut(pRsp->createdDbs, db, len, db, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int32_t i = 0; i < numOfReadDbs; ++i) {
|
for (int32_t i = 0; i < numOfReadDbs; ++i) {
|
||||||
char db[TSDB_DB_FNAME_LEN] = {0};
|
char db[TSDB_DB_FNAME_LEN] = {0};
|
||||||
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
||||||
int32_t len = strlen(db) + 1;
|
int32_t len = strlen(db);
|
||||||
taosHashPut(pRsp->readDbs, db, len, db, len);
|
taosHashPut(pRsp->readDbs, db, len, db, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int32_t i = 0; i < numOfWriteDbs; ++i) {
|
for (int32_t i = 0; i < numOfWriteDbs; ++i) {
|
||||||
char db[TSDB_DB_FNAME_LEN] = {0};
|
char db[TSDB_DB_FNAME_LEN] = {0};
|
||||||
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
if (tDecodeCStrTo(pDecoder, db) < 0) return -1;
|
||||||
int32_t len = strlen(db) + 1;
|
int32_t len = strlen(db);
|
||||||
taosHashPut(pRsp->writeDbs, db, len, db, len);
|
taosHashPut(pRsp->writeDbs, db, len, db, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -367,8 +367,8 @@ TEST_F(MndTestUser, 03_Alter_User) {
|
||||||
EXPECT_EQ(numOfReadDbs, 1);
|
EXPECT_EQ(numOfReadDbs, 1);
|
||||||
EXPECT_EQ(numOfWriteDbs, 0);
|
EXPECT_EQ(numOfWriteDbs, 0);
|
||||||
|
|
||||||
char* dbname = (char*)taosHashGet(authRsp.readDbs, "1.d2", 5);
|
char* dbname = (char*)taosHashGet(authRsp.readDbs, "1.d2", 4);
|
||||||
EXPECT_STREQ(dbname, "1.d2");
|
EXPECT_TRUE(dbname != NULL);
|
||||||
|
|
||||||
taosHashCleanup(authRsp.readDbs);
|
taosHashCleanup(authRsp.readDbs);
|
||||||
taosHashCleanup(authRsp.writeDbs);
|
taosHashCleanup(authRsp.writeDbs);
|
||||||
|
|
|
@ -326,6 +326,11 @@ int tsdbInsertTableData(STsdb *pTsdb, SSubmitMsgIter *pMsgIter, SSubmitBlk *pBlo
|
||||||
|
|
||||||
tSkipListPutBatchByIter(pTbData->pData, &blkIter, (iter_next_fn_t)tGetSubmitBlkNext);
|
tSkipListPutBatchByIter(pTbData->pData, &blkIter, (iter_next_fn_t)tGetSubmitBlkNext);
|
||||||
|
|
||||||
|
#ifdef TD_DEBUG_PRINT_ROW
|
||||||
|
printf("!!! %s:%d table %" PRIi64 " has %d rows in skiplist\n\n", __func__, __LINE__, pTbData->uid,
|
||||||
|
SL_SIZE(pTbData->pData));
|
||||||
|
#endif
|
||||||
|
|
||||||
// Set statistics
|
// Set statistics
|
||||||
keyMax = TD_ROW_KEY(blkIter.row);
|
keyMax = TD_ROW_KEY(blkIter.row);
|
||||||
|
|
||||||
|
|
|
@ -3879,7 +3879,7 @@ int32_t tsdbQuerySTableByTagCond(void* pMeta, uint64_t uid, TSKEY skey, const ch
|
||||||
|
|
||||||
if (metaGetTableEntryByUid(&mr, uid) < 0) {
|
if (metaGetTableEntryByUid(&mr, uid) < 0) {
|
||||||
tsdbError("%p failed to get stable, uid:%" PRIu64 ", TID:0x%" PRIx64 " QID:0x%" PRIx64, pMeta, uid, taskId, reqId);
|
tsdbError("%p failed to get stable, uid:%" PRIu64 ", TID:0x%" PRIx64 " QID:0x%" PRIx64, pMeta, uid, taskId, reqId);
|
||||||
terrno = TSDB_CODE_TDB_INVALID_TABLE_ID;
|
terrno = TSDB_CODE_PAR_TABLE_NOT_EXIST;
|
||||||
goto _error;
|
goto _error;
|
||||||
} else {
|
} else {
|
||||||
tsdbDebug("%p succeed to get stable, uid:%" PRIu64 ", TID:0x%" PRIx64 " QID:0x%" PRIx64, pMeta, uid, taskId, reqId);
|
tsdbDebug("%p succeed to get stable, uid:%" PRIu64 ", TID:0x%" PRIx64 " QID:0x%" PRIx64, pMeta, uid, taskId, reqId);
|
||||||
|
@ -3949,7 +3949,7 @@ int32_t tsdbGetOneTableGroup(void* pMeta, uint64_t uid, TSKEY startKey, STableGr
|
||||||
metaReaderInit(&mr, (SMeta*)pMeta, 0);
|
metaReaderInit(&mr, (SMeta*)pMeta, 0);
|
||||||
|
|
||||||
if (metaGetTableEntryByUid(&mr, uid) < 0) {
|
if (metaGetTableEntryByUid(&mr, uid) < 0) {
|
||||||
terrno = TSDB_CODE_TDB_INVALID_TABLE_ID;
|
terrno = TSDB_CODE_PAR_TABLE_NOT_EXIST;
|
||||||
goto _error;
|
goto _error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -497,6 +497,47 @@ _exit:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int vnodeDebugPrintSubmitMsg(SVnode *pVnode, SSubmitReq *pMsg, const char* tags) {
|
||||||
|
ASSERT(pMsg != NULL);
|
||||||
|
SSubmitMsgIter msgIter = {0};
|
||||||
|
SMeta *pMeta = pVnode->pMeta;
|
||||||
|
SSubmitBlk *pBlock = NULL;
|
||||||
|
SSubmitBlkIter blkIter = {0};
|
||||||
|
STSRow *row = NULL;
|
||||||
|
STSchema *pSchema = NULL;
|
||||||
|
tb_uid_t suid = 0;
|
||||||
|
|
||||||
|
if (tInitSubmitMsgIter(pMsg, &msgIter) < 0) return -1;
|
||||||
|
while (true) {
|
||||||
|
if (tGetSubmitMsgNext(&msgIter, &pBlock) < 0) return -1;
|
||||||
|
if (pBlock == NULL) break;
|
||||||
|
tInitSubmitBlkIter(&msgIter, pBlock, &blkIter);
|
||||||
|
if (blkIter.row == NULL) continue;
|
||||||
|
if (!pSchema || (suid != msgIter.suid)) {
|
||||||
|
if (pSchema) {
|
||||||
|
taosMemoryFreeClear(pSchema);
|
||||||
|
}
|
||||||
|
pSchema = metaGetTbTSchema(pMeta, msgIter.suid, 0); // TODO: use the real schema
|
||||||
|
if(pSchema) {
|
||||||
|
suid = msgIter.suid;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!pSchema) {
|
||||||
|
printf("%s:%d no valid schema\n", tags, __LINE__);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
char __tags[128] = {0};
|
||||||
|
snprintf(__tags, 128, "%s: uid %" PRIi64 " ", tags, msgIter.uid);
|
||||||
|
while ((row = tGetSubmitBlkNext(&blkIter))) {
|
||||||
|
tdSRowPrint(row, pSchema, __tags);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
taosMemoryFreeClear(pSchema);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int vnodeProcessSubmitReq(SVnode *pVnode, int64_t version, void *pReq, int32_t len, SRpcMsg *pRsp) {
|
static int vnodeProcessSubmitReq(SVnode *pVnode, int64_t version, void *pReq, int32_t len, SRpcMsg *pRsp) {
|
||||||
SSubmitReq *pSubmitReq = (SSubmitReq *)pReq;
|
SSubmitReq *pSubmitReq = (SSubmitReq *)pReq;
|
||||||
SSubmitMsgIter msgIter = {0};
|
SSubmitMsgIter msgIter = {0};
|
||||||
|
@ -508,6 +549,10 @@ static int vnodeProcessSubmitReq(SVnode *pVnode, int64_t version, void *pReq, in
|
||||||
|
|
||||||
pRsp->code = 0;
|
pRsp->code = 0;
|
||||||
|
|
||||||
|
#ifdef TD_DEBUG_PRINT_ROW
|
||||||
|
vnodeDebugPrintSubmitMsg(pVnode, pReq, __func__);
|
||||||
|
#endif
|
||||||
|
|
||||||
// handle the request
|
// handle the request
|
||||||
if (tInitSubmitMsgIter(pSubmitReq, &msgIter) < 0) {
|
if (tInitSubmitMsgIter(pSubmitReq, &msgIter) < 0) {
|
||||||
pRsp->code = TSDB_CODE_INVALID_MSG;
|
pRsp->code = TSDB_CODE_INVALID_MSG;
|
||||||
|
@ -550,7 +595,8 @@ static int vnodeProcessSubmitReq(SVnode *pVnode, int64_t version, void *pReq, in
|
||||||
goto _exit;
|
goto _exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
rsp.numOfRows += nRows;
|
rsp.affectedRows += nRows;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_exit:
|
_exit:
|
||||||
|
|
|
@ -36,7 +36,7 @@ extern "C" {
|
||||||
|
|
||||||
#define CTG_DEFAULT_INVALID_VERSION (-1)
|
#define CTG_DEFAULT_INVALID_VERSION (-1)
|
||||||
|
|
||||||
#define CTG_ERR_CODE_TABLE_NOT_EXIST TSDB_CODE_TDB_INVALID_TABLE_ID
|
#define CTG_ERR_CODE_TABLE_NOT_EXIST TSDB_CODE_PAR_TABLE_NOT_EXIST
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
CTG_READ = 1,
|
CTG_READ = 1,
|
||||||
|
|
|
@ -4199,7 +4199,7 @@ static void destroyOperatorInfo(SOperatorInfo* pOperator) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
taosMemoryFree(pOperator->pExpr);
|
taosMemoryFreeClear(pOperator->pExpr);
|
||||||
taosMemoryFreeClear(pOperator->info);
|
taosMemoryFreeClear(pOperator->info);
|
||||||
taosMemoryFreeClear(pOperator);
|
taosMemoryFreeClear(pOperator);
|
||||||
}
|
}
|
||||||
|
@ -4384,6 +4384,9 @@ void destroySFillOperatorInfo(void* param, int32_t numOfOutput) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void destroyProjectOperatorInfo(void* param, int32_t numOfOutput) {
|
static void destroyProjectOperatorInfo(void* param, int32_t numOfOutput) {
|
||||||
|
if (NULL == param) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
SProjectOperatorInfo* pInfo = (SProjectOperatorInfo*)param;
|
SProjectOperatorInfo* pInfo = (SProjectOperatorInfo*)param;
|
||||||
doDestroyBasicInfo(&pInfo->binfo, numOfOutput);
|
doDestroyBasicInfo(&pInfo->binfo, numOfOutput);
|
||||||
cleanupAggSup(&pInfo->aggSup);
|
cleanupAggSup(&pInfo->aggSup);
|
||||||
|
|
|
@ -241,6 +241,15 @@ static int32_t getTableMetaImpl(SInsertParseContext* pCxt, SToken* pTname, bool
|
||||||
SParseContext* pBasicCtx = pCxt->pComCxt;
|
SParseContext* pBasicCtx = pCxt->pComCxt;
|
||||||
SName name = {0};
|
SName name = {0};
|
||||||
createSName(&name, pTname, pBasicCtx->acctId, pBasicCtx->db, &pCxt->msg);
|
createSName(&name, pTname, pBasicCtx->acctId, pBasicCtx->db, &pCxt->msg);
|
||||||
|
|
||||||
|
char dbFname[TSDB_DB_FNAME_LEN] = {0};
|
||||||
|
tNameGetFullDbName(&name, dbFname);
|
||||||
|
|
||||||
|
bool pass = false;
|
||||||
|
CHECK_CODE(catalogChkAuth(pBasicCtx->pCatalog, pBasicCtx->pTransporter, &pBasicCtx->mgmtEpSet, pBasicCtx->pUser, dbFname, AUTH_TYPE_WRITE, &pass));
|
||||||
|
if (!pass) {
|
||||||
|
return TSDB_CODE_PAR_PERMISSION_DENIED;
|
||||||
|
}
|
||||||
if (isStb) {
|
if (isStb) {
|
||||||
CHECK_CODE(catalogGetSTableMeta(pBasicCtx->pCatalog, pBasicCtx->pTransporter, &pBasicCtx->mgmtEpSet, &name,
|
CHECK_CODE(catalogGetSTableMeta(pBasicCtx->pCatalog, pBasicCtx->pTransporter, &pBasicCtx->mgmtEpSet, &name,
|
||||||
&pCxt->pTableMeta));
|
&pCxt->pTableMeta));
|
||||||
|
@ -1151,6 +1160,7 @@ static int32_t parseInsertBody(SInsertParseContext* pCxt) {
|
||||||
(*pCxt->pStmtCb->setExecInfoFn)(pCxt->pStmtCb->pStmt, pCxt->pVgroupsHashObj, pCxt->pTableBlockHashObj);
|
(*pCxt->pStmtCb->setExecInfoFn)(pCxt->pStmtCb->pStmt, pCxt->pVgroupsHashObj, pCxt->pTableBlockHashObj);
|
||||||
pCxt->pVgroupsHashObj = NULL;
|
pCxt->pVgroupsHashObj = NULL;
|
||||||
pCxt->pTableBlockHashObj = NULL;
|
pCxt->pTableBlockHashObj = NULL;
|
||||||
|
pCxt->pTableMeta = NULL;
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -1276,7 +1286,7 @@ int32_t qBindStmtTagsValue(void *pBlock, void *boundTags, int64_t suid, char *tN
|
||||||
return TSDB_CODE_TSC_OUT_OF_MEMORY;
|
return TSDB_CODE_TSC_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
SSchema* pSchema = getTableTagSchema(pDataBlock->pTableMeta);
|
SSchema* pSchema = pDataBlock->pTableMeta->schema;
|
||||||
SKvParam param = {.builder = &tagBuilder};
|
SKvParam param = {.builder = &tagBuilder};
|
||||||
|
|
||||||
for (int c = 0; c < tags->numOfBound; ++c) {
|
for (int c = 0; c < tags->numOfBound; ++c) {
|
||||||
|
|
|
@ -469,7 +469,7 @@ int32_t mergeTableDataBlocks(SHashObj* pHashObj, uint8_t payloadType, SArray** p
|
||||||
// the maximum expanded size in byte when a row-wise data is converted to SDataRow format
|
// the maximum expanded size in byte when a row-wise data is converted to SDataRow format
|
||||||
int32_t expandSize = isRawPayload ? getRowExpandSize(pOneTableBlock->pTableMeta) : 0;
|
int32_t expandSize = isRawPayload ? getRowExpandSize(pOneTableBlock->pTableMeta) : 0;
|
||||||
int64_t destSize = dataBuf->size + pOneTableBlock->size + pBlocks->numOfRows * expandSize +
|
int64_t destSize = dataBuf->size + pOneTableBlock->size + pBlocks->numOfRows * expandSize +
|
||||||
sizeof(STColumn) * getNumOfColumns(pOneTableBlock->pTableMeta);
|
sizeof(STColumn) * getNumOfColumns(pOneTableBlock->pTableMeta) + pOneTableBlock->createTbReqLen;
|
||||||
|
|
||||||
if (dataBuf->nAllocSize < destSize) {
|
if (dataBuf->nAllocSize < destSize) {
|
||||||
dataBuf->nAllocSize = (uint32_t)(destSize * 1.5);
|
dataBuf->nAllocSize = (uint32_t)(destSize * 1.5);
|
||||||
|
@ -601,6 +601,7 @@ int32_t qResetStmtDataBlock(void* block, bool keepBuf) {
|
||||||
pBlock->numOfTables = 1;
|
pBlock->numOfTables = 1;
|
||||||
pBlock->nAllocSize = TSDB_PAYLOAD_SIZE;
|
pBlock->nAllocSize = TSDB_PAYLOAD_SIZE;
|
||||||
pBlock->headerSize = pBlock->size;
|
pBlock->headerSize = pBlock->size;
|
||||||
|
pBlock->createTbReqLen = 0;
|
||||||
|
|
||||||
memset(&pBlock->rowBuilder, 0, sizeof(pBlock->rowBuilder));
|
memset(&pBlock->rowBuilder, 0, sizeof(pBlock->rowBuilder));
|
||||||
|
|
||||||
|
|
|
@ -2579,7 +2579,7 @@ static int32_t translateDropTable(STranslateContext* pCxt, SDropTableStmt* pStmt
|
||||||
SName tableName;
|
SName tableName;
|
||||||
int32_t code = getTableMetaImpl(
|
int32_t code = getTableMetaImpl(
|
||||||
pCxt, toName(pCxt->pParseCxt->acctId, pClause->dbName, pClause->tableName, &tableName), &pTableMeta);
|
pCxt, toName(pCxt->pParseCxt->acctId, pClause->dbName, pClause->tableName, &tableName), &pTableMeta);
|
||||||
if ((TSDB_CODE_TDB_INVALID_TABLE_ID == code || TSDB_CODE_VND_TB_NOT_EXIST == code) && pClause->ignoreNotExists) {
|
if ((TSDB_CODE_PAR_TABLE_NOT_EXIST == code || TSDB_CODE_VND_TB_NOT_EXIST == code) && pClause->ignoreNotExists) {
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
if (TSDB_CODE_SUCCESS == code) {
|
if (TSDB_CODE_SUCCESS == code) {
|
||||||
|
@ -3150,7 +3150,7 @@ static int32_t translateGrant(STranslateContext* pCxt, SGrantStmt* pStmt) {
|
||||||
req.alterType = TSDB_ALTER_USER_ADD_WRITE_DB;
|
req.alterType = TSDB_ALTER_USER_ADD_WRITE_DB;
|
||||||
}
|
}
|
||||||
strcpy(req.user, pStmt->userName);
|
strcpy(req.user, pStmt->userName);
|
||||||
strcpy(req.dbname, pStmt->dbName);
|
sprintf(req.dbname, "%d.%s", pCxt->pParseCxt->acctId, pStmt->dbName);
|
||||||
return buildCmdMsg(pCxt, TDMT_MND_ALTER_USER, (FSerializeFunc)tSerializeSAlterUserReq, &req);
|
return buildCmdMsg(pCxt, TDMT_MND_ALTER_USER, (FSerializeFunc)tSerializeSAlterUserReq, &req);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3577,6 +3577,22 @@ EDealRes fltReviseRewriter(SNode** pNode, void* pContext) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (QUERY_NODE_NODE_LIST == nodeType(*pNode)) {
|
if (QUERY_NODE_NODE_LIST == nodeType(*pNode)) {
|
||||||
|
SNodeListNode *listNode = (SNodeListNode *)*pNode;
|
||||||
|
if (QUERY_NODE_VALUE != nodeType(listNode->pNodeList->pHead->pNode)) {
|
||||||
|
stat->scalarMode = true;
|
||||||
|
return DEAL_RES_CONTINUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
SValueNode *valueNode = (SValueNode *)listNode->pNodeList->pHead->pNode;
|
||||||
|
uint8_t type = valueNode->node.resType.type;
|
||||||
|
SNode *node = NULL;
|
||||||
|
FOREACH(node, listNode->pNodeList) {
|
||||||
|
if (type != ((SValueNode *)node)->node.resType.type) {
|
||||||
|
stat->scalarMode = true;
|
||||||
|
return DEAL_RES_CONTINUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return DEAL_RES_CONTINUE;
|
return DEAL_RES_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -265,13 +265,53 @@ static FORCE_INLINE void varToTimestamp(char *buf, SScalarParam* pOut, int32_t r
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE void varToSigned(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
static FORCE_INLINE void varToSigned(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
||||||
int64_t value = strtoll(buf, NULL, 10);
|
switch (pOut->columnData->info.type) {
|
||||||
colDataAppendInt64(pOut->columnData, rowIndex, &value);
|
case TSDB_DATA_TYPE_TINYINT: {
|
||||||
|
int8_t value = (int8_t)strtoll(buf, NULL, 10);
|
||||||
|
colDataAppendInt8(pOut->columnData, rowIndex, (int8_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_SMALLINT: {
|
||||||
|
int16_t value = (int16_t)strtoll(buf, NULL, 10);
|
||||||
|
colDataAppendInt16(pOut->columnData, rowIndex, (int16_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_INT: {
|
||||||
|
int32_t value = (int32_t)strtoll(buf, NULL, 10);
|
||||||
|
colDataAppendInt32(pOut->columnData, rowIndex, (int32_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_BIGINT: {
|
||||||
|
int64_t value = (int64_t)strtoll(buf, NULL, 10);
|
||||||
|
colDataAppendInt64(pOut->columnData, rowIndex, (int64_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE void varToUnsigned(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
static FORCE_INLINE void varToUnsigned(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
||||||
uint64_t value = strtoull(buf, NULL, 10);
|
switch (pOut->columnData->info.type) {
|
||||||
colDataAppendInt64(pOut->columnData, rowIndex, (int64_t*) &value);
|
case TSDB_DATA_TYPE_UTINYINT: {
|
||||||
|
uint8_t value = (uint8_t)strtoull(buf, NULL, 10);
|
||||||
|
colDataAppendInt8(pOut->columnData, rowIndex, (int8_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_USMALLINT: {
|
||||||
|
uint16_t value = (uint16_t)strtoull(buf, NULL, 10);
|
||||||
|
colDataAppendInt16(pOut->columnData, rowIndex, (int16_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_UINT: {
|
||||||
|
uint32_t value = (uint32_t)strtoull(buf, NULL, 10);
|
||||||
|
colDataAppendInt32(pOut->columnData, rowIndex, (int32_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case TSDB_DATA_TYPE_UBIGINT: {
|
||||||
|
uint64_t value = (uint64_t)strtoull(buf, NULL, 10);
|
||||||
|
colDataAppendInt64(pOut->columnData, rowIndex, (int64_t*)&value);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static FORCE_INLINE void varToFloat(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
static FORCE_INLINE void varToFloat(char *buf, SScalarParam* pOut, int32_t rowIndex) {
|
||||||
|
@ -453,6 +493,71 @@ void convertJsonValue(__compar_fn_t *fp, int32_t optr, int8_t typeLeft, int8_t t
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t vectorConvertToVarData(const SScalarParam* pIn, SScalarParam* pOut, int16_t inType, int16_t outType) {
|
||||||
|
SColumnInfoData* pInputCol = pIn->columnData;
|
||||||
|
SColumnInfoData* pOutputCol = pOut->columnData;
|
||||||
|
char tmp[128] = {0};
|
||||||
|
|
||||||
|
if (IS_SIGNED_NUMERIC_TYPE(inType) || inType == TSDB_DATA_TYPE_BOOL || inType == TSDB_DATA_TYPE_TIMESTAMP) {
|
||||||
|
for (int32_t i = 0; i < pIn->numOfRows; ++i) {
|
||||||
|
if (colDataIsNull_f(pInputCol->nullbitmap, i)) {
|
||||||
|
colDataAppendNULL(pOutputCol, i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
int64_t value = 0;
|
||||||
|
GET_TYPED_DATA(value, int64_t, inType, colDataGetData(pInputCol, i));
|
||||||
|
int32_t len = sprintf(varDataVal(tmp), "%" PRId64, value);
|
||||||
|
varDataLen(tmp) = len;
|
||||||
|
if (outType == TSDB_DATA_TYPE_NCHAR) {
|
||||||
|
varToNchar(tmp, pOut, i);
|
||||||
|
} else {
|
||||||
|
colDataAppend(pOutputCol, i, (char *)&value, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (IS_UNSIGNED_NUMERIC_TYPE(inType)) {
|
||||||
|
for (int32_t i = 0; i < pIn->numOfRows; ++i) {
|
||||||
|
if (colDataIsNull_f(pInputCol->nullbitmap, i)) {
|
||||||
|
colDataAppendNULL(pOutputCol, i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t value = 0;
|
||||||
|
GET_TYPED_DATA(value, uint64_t, inType, colDataGetData(pInputCol, i));
|
||||||
|
int32_t len = sprintf(varDataVal(tmp), "%" PRIu64, value);
|
||||||
|
varDataLen(tmp) = len;
|
||||||
|
if (outType == TSDB_DATA_TYPE_NCHAR) {
|
||||||
|
varToNchar(tmp, pOut, i);
|
||||||
|
} else {
|
||||||
|
colDataAppend(pOutputCol, i, (char *)&value, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (IS_FLOAT_TYPE(inType)) {
|
||||||
|
for (int32_t i = 0; i < pIn->numOfRows; ++i) {
|
||||||
|
if (colDataIsNull_f(pInputCol->nullbitmap, i)) {
|
||||||
|
colDataAppendNULL(pOutputCol, i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
double value = 0;
|
||||||
|
GET_TYPED_DATA(value, double, inType, colDataGetData(pInputCol, i));
|
||||||
|
int32_t len = sprintf(varDataVal(tmp), "%lf", value);
|
||||||
|
varDataLen(tmp) = len;
|
||||||
|
if (outType == TSDB_DATA_TYPE_NCHAR) {
|
||||||
|
varToNchar(tmp, pOut, i);
|
||||||
|
} else {
|
||||||
|
colDataAppend(pOutputCol, i, (char *)&value, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sclError("not supported input type:%d", inType);
|
||||||
|
return TSDB_CODE_QRY_APP_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TSDB_CODE_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// TODO opt performance
|
// TODO opt performance
|
||||||
int32_t vectorConvertImpl(const SScalarParam* pIn, SScalarParam* pOut) {
|
int32_t vectorConvertImpl(const SScalarParam* pIn, SScalarParam* pOut) {
|
||||||
SColumnInfoData* pInputCol = pIn->columnData;
|
SColumnInfoData* pInputCol = pIn->columnData;
|
||||||
|
@ -610,6 +715,10 @@ int32_t vectorConvertImpl(const SScalarParam* pIn, SScalarParam* pOut) {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case TSDB_DATA_TYPE_BINARY:
|
||||||
|
case TSDB_DATA_TYPE_NCHAR: {
|
||||||
|
return vectorConvertToVarData(pIn, pOut, inType, outType);
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
sclError("invalid convert output type:%d", outType);
|
sclError("invalid convert output type:%d", outType);
|
||||||
return TSDB_CODE_QRY_APP_ERROR;
|
return TSDB_CODE_QRY_APP_ERROR;
|
||||||
|
|
|
@ -94,6 +94,7 @@ TAOS_DEFINE_ERROR(TSDB_CODE_MSG_NOT_PROCESSED, "Message not processed
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_CFG_NOT_FOUND, "Config not found")
|
TAOS_DEFINE_ERROR(TSDB_CODE_CFG_NOT_FOUND, "Config not found")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_REPEAT_INIT, "Repeat initialization")
|
TAOS_DEFINE_ERROR(TSDB_CODE_REPEAT_INIT, "Repeat initialization")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_DUP_KEY, "Cannot add duplicate keys to hash")
|
TAOS_DEFINE_ERROR(TSDB_CODE_DUP_KEY, "Cannot add duplicate keys to hash")
|
||||||
|
TAOS_DEFINE_ERROR(TSDB_CODE_NEED_RETRY, "Retry needed")
|
||||||
|
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_REF_NO_MEMORY, "Ref out of memory")
|
TAOS_DEFINE_ERROR(TSDB_CODE_REF_NO_MEMORY, "Ref out of memory")
|
||||||
TAOS_DEFINE_ERROR(TSDB_CODE_REF_FULL, "too many Ref Objs")
|
TAOS_DEFINE_ERROR(TSDB_CODE_REF_FULL, "too many Ref Objs")
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
|
|
||||||
int32_t shortColList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_INT};
|
int32_t shortColList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_INT};
|
||||||
int32_t fullColList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_BOOL, TSDB_DATA_TYPE_TINYINT, TSDB_DATA_TYPE_UTINYINT, TSDB_DATA_TYPE_SMALLINT, TSDB_DATA_TYPE_USMALLINT, TSDB_DATA_TYPE_INT, TSDB_DATA_TYPE_UINT, TSDB_DATA_TYPE_BIGINT, TSDB_DATA_TYPE_UBIGINT, TSDB_DATA_TYPE_FLOAT, TSDB_DATA_TYPE_DOUBLE, TSDB_DATA_TYPE_BINARY, TSDB_DATA_TYPE_NCHAR};
|
int32_t fullColList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_BOOL, TSDB_DATA_TYPE_TINYINT, TSDB_DATA_TYPE_UTINYINT, TSDB_DATA_TYPE_SMALLINT, TSDB_DATA_TYPE_USMALLINT, TSDB_DATA_TYPE_INT, TSDB_DATA_TYPE_UINT, TSDB_DATA_TYPE_BIGINT, TSDB_DATA_TYPE_UBIGINT, TSDB_DATA_TYPE_FLOAT, TSDB_DATA_TYPE_DOUBLE, TSDB_DATA_TYPE_BINARY, TSDB_DATA_TYPE_NCHAR};
|
||||||
int32_t bindColTypeList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_SMALLINT, TSDB_DATA_TYPE_DOUBLE};
|
int32_t bindColTypeList[] = {TSDB_DATA_TYPE_TIMESTAMP, TSDB_DATA_TYPE_SMALLINT, TSDB_DATA_TYPE_NCHAR};
|
||||||
int32_t optrIdxList[] = {0, 1, 2};
|
int32_t optrIdxList[] = {0, 1, 2};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -20,6 +20,11 @@ typedef struct {
|
||||||
bool enclose;
|
bool enclose;
|
||||||
} OperInfo;
|
} OperInfo;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
BP_BIND_TAG = 1,
|
||||||
|
BP_BIND_COL,
|
||||||
|
} BP_BIND_TYPE;
|
||||||
|
|
||||||
OperInfo operInfo[] = {
|
OperInfo operInfo[] = {
|
||||||
{">", 2, false},
|
{">", 2, false},
|
||||||
{">=", 2, false},
|
{">=", 2, false},
|
||||||
|
@ -41,6 +46,8 @@ int32_t varoperatorList[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11};
|
||||||
|
|
||||||
char *bpStbPrefix = "st";
|
char *bpStbPrefix = "st";
|
||||||
char *bpTbPrefix = "t";
|
char *bpTbPrefix = "t";
|
||||||
|
int32_t bpDefaultStbId = 1;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//char *operatorList[] = {">", ">=", "<", "<=", "=", "<>", "in", "not in"};
|
//char *operatorList[] = {">", ">=", "<", "<=", "=", "<>", "in", "not in"};
|
||||||
|
@ -65,6 +72,7 @@ typedef struct {
|
||||||
char* isNull;
|
char* isNull;
|
||||||
int32_t* binaryLen;
|
int32_t* binaryLen;
|
||||||
TAOS_MULTI_BIND* pBind;
|
TAOS_MULTI_BIND* pBind;
|
||||||
|
TAOS_MULTI_BIND* pTags;
|
||||||
char* sql;
|
char* sql;
|
||||||
int32_t* colTypes;
|
int32_t* colTypes;
|
||||||
int32_t colNum;
|
int32_t colNum;
|
||||||
|
@ -83,6 +91,7 @@ int insertMBMETest2(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertMBMETest3(TAOS_STMT *stmt, TAOS *taos);
|
int insertMBMETest3(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertMBMETest4(TAOS_STMT *stmt, TAOS *taos);
|
int insertMBMETest4(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos);
|
int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos);
|
||||||
|
int insertAUTOTest1(TAOS_STMT *stmt, TAOS *taos);
|
||||||
int querySUBTTest1(TAOS_STMT *stmt, TAOS *taos);
|
int querySUBTTest1(TAOS_STMT *stmt, TAOS *taos);
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -95,52 +104,55 @@ typedef struct {
|
||||||
int32_t colNum;
|
int32_t colNum;
|
||||||
int32_t *colList; // full table column list
|
int32_t *colList; // full table column list
|
||||||
int32_t testType;
|
int32_t testType;
|
||||||
bool prepareStb;
|
bool autoCreateTbl;
|
||||||
bool fullCol;
|
bool fullCol;
|
||||||
int32_t (*runFn)(TAOS_STMT*, TAOS*);
|
int32_t (*runFn)(TAOS_STMT*, TAOS*);
|
||||||
int32_t tblNum;
|
int32_t tblNum;
|
||||||
int32_t rowNum;
|
int32_t rowNum;
|
||||||
int32_t bindRowNum;
|
int32_t bindRowNum;
|
||||||
int32_t bindColNum; // equal colNum in full column case
|
int32_t bindColNum; // equal colNum in full column case
|
||||||
|
int32_t bindTagNum; // equal colNum in full column case
|
||||||
int32_t bindNullNum;
|
int32_t bindNullNum;
|
||||||
int32_t runTimes;
|
int32_t runTimes;
|
||||||
int32_t preCaseIdx;
|
int32_t preCaseIdx;
|
||||||
} CaseCfg;
|
} CaseCfg;
|
||||||
|
|
||||||
CaseCfg gCase[] = {
|
CaseCfg gCase[] = {
|
||||||
{"insert:MBSE1-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 1, 10, 10, 0, 0, 1, -1},
|
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 1, 10, 10, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE1-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 100, 10, 0, 0, 1, -1},
|
{"insert:MBSE0-FULL", tListLen(shortColList), shortColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 100, 10, 0, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBSE1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBSE1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBSE1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBSE1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBSE1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBSE2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest2, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBSE2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBSETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBSE2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBSE2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBSE2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBSE2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBSETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest1, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBME1-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest1, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
// 11
|
// 11
|
||||||
{"insert:MBME2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest2, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBME2-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest2, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBME2-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBME2-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest2, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME3-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest3, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBME3-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest3, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME3-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBME3-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME3-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBME3-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest3, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MBME4-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest4, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MBME4-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMBMETest4, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MBME4-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MBME4-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
{"insert:MBME4-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 2, 0, 1, -1},
|
{"insert:MBME4-C002", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMBMETest4, 10, 10, 2, 2, 0, 0, 1, -1},
|
||||||
|
|
||||||
{"insert:MPME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMPMETest1, 10, 10, 2, 0, 0, 1, -1},
|
{"insert:MPME1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, false, true, insertMPMETest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
{"insert:MPME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMPMETest1, 10, 10, 2, 12, 0, 1, -1},
|
{"insert:MPME1-C012", tListLen(fullColList), fullColList, TTYPE_INSERT, false, false, insertMPMETest1, 10, 10, 2, 12, 0, 0, 1, -1},
|
||||||
|
|
||||||
// 22
|
// 22
|
||||||
{"query:SUBT-FULL", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, querySUBTTest1, 10, 10, 1, 3, 0, 1, 2},
|
{"insert:AUTO1-FULL", tListLen(fullColList), fullColList, TTYPE_INSERT, true, true, insertAUTOTest1, 10, 10, 2, 0, 0, 0, 1, -1},
|
||||||
|
|
||||||
|
{"query:SUBT-FULL", tListLen(fullColList), fullColList, TTYPE_QUERY, false, false, querySUBTTest1, 10, 10, 1, 3, 0, 0, 1, 2},
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -149,17 +161,20 @@ CaseCfg *gCurCase = NULL;
|
||||||
typedef struct {
|
typedef struct {
|
||||||
char caseCatalog[255];
|
char caseCatalog[255];
|
||||||
int32_t bindNullNum;
|
int32_t bindNullNum;
|
||||||
bool prepareStb;
|
|
||||||
bool checkParamNum;
|
bool checkParamNum;
|
||||||
bool printRes;
|
bool printRes;
|
||||||
bool printCreateTblSql;
|
bool printCreateTblSql;
|
||||||
bool printQuerySql;
|
bool printQuerySql;
|
||||||
bool printStmtSql;
|
bool printStmtSql;
|
||||||
|
bool autoCreateTbl;
|
||||||
int32_t rowNum; //row num for one table
|
int32_t rowNum; //row num for one table
|
||||||
int32_t bindColNum;
|
int32_t bindColNum;
|
||||||
|
int32_t bindTagNum;
|
||||||
int32_t bindRowNum; //row num for once bind
|
int32_t bindRowNum; //row num for once bind
|
||||||
int32_t bindColTypeNum;
|
int32_t bindColTypeNum;
|
||||||
int32_t* bindColTypeList;
|
int32_t* bindColTypeList;
|
||||||
|
int32_t bindTagTypeNum;
|
||||||
|
int32_t* bindTagTypeList;
|
||||||
int32_t optrIdxListNum;
|
int32_t optrIdxListNum;
|
||||||
int32_t* optrIdxList;
|
int32_t* optrIdxList;
|
||||||
int32_t runTimes;
|
int32_t runTimes;
|
||||||
|
@ -172,15 +187,18 @@ typedef struct {
|
||||||
#if 0
|
#if 0
|
||||||
CaseCtrl gCaseCtrl = { // default
|
CaseCtrl gCaseCtrl = { // default
|
||||||
.bindNullNum = 0,
|
.bindNullNum = 0,
|
||||||
.prepareStb = false,
|
|
||||||
.printCreateTblSql = false,
|
.printCreateTblSql = false,
|
||||||
.printQuerySql = true,
|
.printQuerySql = true,
|
||||||
.printStmtSql = true,
|
.printStmtSql = true,
|
||||||
|
.autoCreateTbl = false,
|
||||||
.rowNum = 0,
|
.rowNum = 0,
|
||||||
.bindColNum = 0,
|
.bindColNum = 0,
|
||||||
|
.bindTagNum = 0,
|
||||||
.bindRowNum = 0,
|
.bindRowNum = 0,
|
||||||
.bindColTypeNum = 0,
|
.bindColTypeNum = 0,
|
||||||
.bindColTypeList = NULL,
|
.bindColTypeList = NULL,
|
||||||
|
.bindTagTypeNum = 0,
|
||||||
|
.bindTagTypeList = NULL,
|
||||||
.optrIdxListNum = 0,
|
.optrIdxListNum = 0,
|
||||||
.optrIdxList = NULL,
|
.optrIdxList = NULL,
|
||||||
.checkParamNum = false,
|
.checkParamNum = false,
|
||||||
|
@ -193,10 +211,37 @@ CaseCtrl gCaseCtrl = { // default
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
CaseCtrl gCaseCtrl = { // default
|
||||||
|
.bindNullNum = 0,
|
||||||
|
.printCreateTblSql = true,
|
||||||
|
.printQuerySql = true,
|
||||||
|
.printStmtSql = true,
|
||||||
|
.autoCreateTbl = false,
|
||||||
|
.rowNum = 0,
|
||||||
|
.bindColNum = 0,
|
||||||
|
.bindTagNum = 0,
|
||||||
|
.bindRowNum = 0,
|
||||||
|
.bindColTypeNum = 0,
|
||||||
|
.bindColTypeList = NULL,
|
||||||
|
.bindTagTypeNum = 0,
|
||||||
|
.bindTagTypeList = NULL,
|
||||||
|
.optrIdxListNum = 0,
|
||||||
|
.optrIdxList = NULL,
|
||||||
|
.checkParamNum = false,
|
||||||
|
.printRes = true,
|
||||||
|
.runTimes = 0,
|
||||||
|
.caseIdx = -1,
|
||||||
|
.caseNum = 1,
|
||||||
|
.caseRunIdx = 11,
|
||||||
|
.caseRunNum = 1,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
CaseCtrl gCaseCtrl = { // query case with specified col&oper
|
CaseCtrl gCaseCtrl = { // query case with specified col&oper
|
||||||
.bindNullNum = 0,
|
.bindNullNum = 0,
|
||||||
.prepareStb = false,
|
|
||||||
.printCreateTblSql = false,
|
.printCreateTblSql = false,
|
||||||
.printQuerySql = true,
|
.printQuerySql = true,
|
||||||
.printStmtSql = true,
|
.printStmtSql = true,
|
||||||
|
@ -221,28 +266,29 @@ CaseCtrl gCaseCtrl = { // query case with specified col&oper
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if 1
|
#if 0
|
||||||
CaseCtrl gCaseCtrl = { // query case with specified col&oper
|
CaseCtrl gCaseCtrl = { // query case with specified col&oper
|
||||||
.bindNullNum = 0,
|
.bindNullNum = 0,
|
||||||
.prepareStb = false,
|
.printCreateTblSql = true,
|
||||||
.printCreateTblSql = false,
|
|
||||||
.printQuerySql = true,
|
.printQuerySql = true,
|
||||||
.printStmtSql = true,
|
.printStmtSql = true,
|
||||||
|
.autoCreateTbl = true,
|
||||||
.rowNum = 0,
|
.rowNum = 0,
|
||||||
.bindColNum = 0,
|
.bindColNum = 0,
|
||||||
|
.bindTagNum = 0,
|
||||||
.bindRowNum = 0,
|
.bindRowNum = 0,
|
||||||
.bindColTypeNum = 0,
|
.bindColTypeNum = 0,
|
||||||
.bindColTypeList = NULL,
|
.bindColTypeList = NULL,
|
||||||
.optrIdxListNum = 0,
|
.optrIdxListNum = 0,
|
||||||
.optrIdxList = NULL,
|
.optrIdxList = NULL,
|
||||||
.checkParamNum = true,
|
.checkParamNum = false,
|
||||||
.printRes = true,
|
.printRes = true,
|
||||||
.runTimes = 0,
|
.runTimes = 0,
|
||||||
.caseRunIdx = -1,
|
.caseRunIdx = -1,
|
||||||
.optrIdxListNum = tListLen(optrIdxList),
|
//.optrIdxListNum = tListLen(optrIdxList),
|
||||||
.optrIdxList = optrIdxList,
|
//.optrIdxList = optrIdxList,
|
||||||
.bindColTypeNum = tListLen(bindColTypeList),
|
//.bindColTypeNum = tListLen(bindColTypeList),
|
||||||
.bindColTypeList = bindColTypeList,
|
//.bindColTypeList = bindColTypeList,
|
||||||
.caseIdx = 22,
|
.caseIdx = 22,
|
||||||
.caseNum = 1,
|
.caseNum = 1,
|
||||||
.caseRunNum = 1,
|
.caseRunNum = 1,
|
||||||
|
@ -299,6 +345,78 @@ void generateInsertSQL(BindData *data) {
|
||||||
} else {
|
} else {
|
||||||
len = sprintf(data->sql, "insert into %s0 ", bpTbPrefix);
|
len = sprintf(data->sql, "insert into %s0 ", bpTbPrefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (gCurCase->bindTagNum > 0) {
|
||||||
|
len += sprintf(data->sql + len, "using %s%d ", bpStbPrefix, bpDefaultStbId);
|
||||||
|
|
||||||
|
if (!gCurCase->fullCol) {
|
||||||
|
len += sprintf(data->sql + len, "(");
|
||||||
|
for (int c = 0; c < gCurCase->bindTagNum; ++c) {
|
||||||
|
if (c) {
|
||||||
|
len += sprintf(data->sql + len, ",");
|
||||||
|
}
|
||||||
|
switch (data->pTags[c].buffer_type) {
|
||||||
|
case TSDB_DATA_TYPE_BOOL:
|
||||||
|
len += sprintf(data->sql + len, "tbooldata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TINYINT:
|
||||||
|
len += sprintf(data->sql + len, "ttinydata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_SMALLINT:
|
||||||
|
len += sprintf(data->sql + len, "tsmalldata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_INT:
|
||||||
|
len += sprintf(data->sql + len, "tintdata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_BIGINT:
|
||||||
|
len += sprintf(data->sql + len, "tbigdata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_FLOAT:
|
||||||
|
len += sprintf(data->sql + len, "tfloatdata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_DOUBLE:
|
||||||
|
len += sprintf(data->sql + len, "tdoubledata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
|
len += sprintf(data->sql + len, "tbinarydata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TIMESTAMP:
|
||||||
|
len += sprintf(data->sql + len, "tts");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_NCHAR:
|
||||||
|
len += sprintf(data->sql + len, "tnchardata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UTINYINT:
|
||||||
|
len += sprintf(data->sql + len, "tutinydata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_USMALLINT:
|
||||||
|
len += sprintf(data->sql + len, "tusmalldata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UINT:
|
||||||
|
len += sprintf(data->sql + len, "tuintdata");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UBIGINT:
|
||||||
|
len += sprintf(data->sql + len, "tubigdata");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("!!!invalid tag type:%d", data->pTags[c].buffer_type);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
len += sprintf(data->sql + len, ") ");
|
||||||
|
}
|
||||||
|
|
||||||
|
len += sprintf(data->sql + len, "tags (");
|
||||||
|
for (int c = 0; c < gCurCase->bindTagNum; ++c) {
|
||||||
|
if (c) {
|
||||||
|
len += sprintf(data->sql + len, ",");
|
||||||
|
}
|
||||||
|
len += sprintf(data->sql + len, "?");
|
||||||
|
}
|
||||||
|
len += sprintf(data->sql + len, ") ");
|
||||||
|
}
|
||||||
|
|
||||||
if (!gCurCase->fullCol) {
|
if (!gCurCase->fullCol) {
|
||||||
len += sprintf(data->sql + len, "(");
|
len += sprintf(data->sql + len, "(");
|
||||||
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
||||||
|
@ -528,6 +646,7 @@ void generateQueryMiscSQL(BindData *data, int32_t tblIdx) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void generateErrorSQL(BindData *data, int32_t tblIdx) {
|
void generateErrorSQL(BindData *data, int32_t tblIdx) {
|
||||||
int32_t len = 0;
|
int32_t len = 0;
|
||||||
data->sql = taosMemoryCalloc(1, 1024);
|
data->sql = taosMemoryCalloc(1, 1024);
|
||||||
|
@ -552,7 +671,7 @@ void generateErrorSQL(BindData *data, int32_t tblIdx) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void generateDataType(BindData *data, int32_t bindIdx, int32_t colIdx, int32_t *dataType) {
|
void generateColDataType(BindData *data, int32_t bindIdx, int32_t colIdx, int32_t *dataType) {
|
||||||
if (bindIdx < gCurCase->bindColNum) {
|
if (bindIdx < gCurCase->bindColNum) {
|
||||||
if (gCaseCtrl.bindColTypeNum) {
|
if (gCaseCtrl.bindColTypeNum) {
|
||||||
*dataType = gCaseCtrl.bindColTypeList[colIdx];
|
*dataType = gCaseCtrl.bindColTypeList[colIdx];
|
||||||
|
@ -584,103 +703,145 @@ void generateDataType(BindData *data, int32_t bindIdx, int32_t colIdx, int32_t *
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t prepareColData(BindData *data, int32_t bindIdx, int32_t rowIdx, int32_t colIdx) {
|
void generateTagDataType(BindData *data, int32_t bindIdx, int32_t colIdx, int32_t *dataType) {
|
||||||
int32_t dataType = TSDB_DATA_TYPE_TIMESTAMP;
|
if (bindIdx < gCurCase->bindTagNum) {
|
||||||
|
if (gCaseCtrl.bindTagTypeNum) {
|
||||||
|
*dataType = gCaseCtrl.bindTagTypeList[colIdx];
|
||||||
|
return;
|
||||||
|
} else if (gCurCase->fullCol) {
|
||||||
|
*dataType = gCurCase->colList[bindIdx];
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
while (true) {
|
||||||
|
*dataType = rand() % (TSDB_DATA_TYPE_MAX - 1) + 1;
|
||||||
|
if (*dataType == TSDB_DATA_TYPE_JSON || *dataType == TSDB_DATA_TYPE_DECIMAL
|
||||||
|
|| *dataType == TSDB_DATA_TYPE_BLOB || *dataType == TSDB_DATA_TYPE_MEDIUMBLOB
|
||||||
|
|| *dataType == TSDB_DATA_TYPE_VARBINARY) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (colExists(data->pTags, *dataType)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
*dataType = data->pTags[bindIdx%gCurCase->bindTagNum].buffer_type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int32_t prepareColData(BP_BIND_TYPE bType, BindData *data, int32_t bindIdx, int32_t rowIdx, int32_t colIdx) {
|
||||||
|
int32_t dataType = TSDB_DATA_TYPE_TIMESTAMP;
|
||||||
|
TAOS_MULTI_BIND *pBase = NULL;
|
||||||
|
|
||||||
|
if (bType == BP_BIND_TAG) {
|
||||||
|
pBase = data->pTags;
|
||||||
|
generateTagDataType(data, bindIdx, colIdx, &dataType);
|
||||||
|
} else {
|
||||||
|
pBase = data->pBind;
|
||||||
|
generateColDataType(data, bindIdx, colIdx, &dataType);
|
||||||
|
}
|
||||||
|
|
||||||
generateDataType(data, bindIdx, colIdx, &dataType);
|
|
||||||
|
|
||||||
switch (dataType) {
|
switch (dataType) {
|
||||||
case TSDB_DATA_TYPE_BOOL:
|
case TSDB_DATA_TYPE_BOOL:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(bool);
|
pBase[bindIdx].buffer_length = sizeof(bool);
|
||||||
data->pBind[bindIdx].buffer = data->boolData + rowIdx;
|
pBase[bindIdx].buffer = data->boolData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_TINYINT:
|
case TSDB_DATA_TYPE_TINYINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(int8_t);
|
pBase[bindIdx].buffer_length = sizeof(int8_t);
|
||||||
data->pBind[bindIdx].buffer = data->tinyData + rowIdx;
|
pBase[bindIdx].buffer = data->tinyData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_SMALLINT:
|
case TSDB_DATA_TYPE_SMALLINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(int16_t);
|
pBase[bindIdx].buffer_length = sizeof(int16_t);
|
||||||
data->pBind[bindIdx].buffer = data->smallData + rowIdx;
|
pBase[bindIdx].buffer = data->smallData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_INT:
|
case TSDB_DATA_TYPE_INT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(int32_t);
|
pBase[bindIdx].buffer_length = sizeof(int32_t);
|
||||||
data->pBind[bindIdx].buffer = data->intData + rowIdx;
|
pBase[bindIdx].buffer = data->intData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_BIGINT:
|
case TSDB_DATA_TYPE_BIGINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(int64_t);
|
pBase[bindIdx].buffer_length = sizeof(int64_t);
|
||||||
data->pBind[bindIdx].buffer = data->bigData + rowIdx;
|
pBase[bindIdx].buffer = data->bigData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_FLOAT:
|
case TSDB_DATA_TYPE_FLOAT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(float);
|
pBase[bindIdx].buffer_length = sizeof(float);
|
||||||
data->pBind[bindIdx].buffer = data->floatData + rowIdx;
|
pBase[bindIdx].buffer = data->floatData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_DOUBLE:
|
case TSDB_DATA_TYPE_DOUBLE:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(double);
|
pBase[bindIdx].buffer_length = sizeof(double);
|
||||||
data->pBind[bindIdx].buffer = data->doubleData + rowIdx;
|
pBase[bindIdx].buffer = data->doubleData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_VARCHAR:
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
data->pBind[bindIdx].buffer_length = gVarCharSize;
|
pBase[bindIdx].buffer_length = gVarCharSize;
|
||||||
data->pBind[bindIdx].buffer = data->binaryData + rowIdx * gVarCharSize;
|
pBase[bindIdx].buffer = data->binaryData + rowIdx * gVarCharSize;
|
||||||
data->pBind[bindIdx].length = data->binaryLen;
|
pBase[bindIdx].length = data->binaryLen;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_TIMESTAMP:
|
case TSDB_DATA_TYPE_TIMESTAMP:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(int64_t);
|
pBase[bindIdx].buffer_length = sizeof(int64_t);
|
||||||
data->pBind[bindIdx].buffer = data->tsData + rowIdx;
|
pBase[bindIdx].buffer = data->tsData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = NULL;
|
pBase[bindIdx].is_null = NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_NCHAR:
|
case TSDB_DATA_TYPE_NCHAR:
|
||||||
data->pBind[bindIdx].buffer_length = gVarCharSize;
|
pBase[bindIdx].buffer_length = gVarCharSize;
|
||||||
data->pBind[bindIdx].buffer = data->binaryData + rowIdx * gVarCharSize;
|
pBase[bindIdx].buffer = data->binaryData + rowIdx * gVarCharSize;
|
||||||
data->pBind[bindIdx].length = data->binaryLen;
|
pBase[bindIdx].length = data->binaryLen;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_UTINYINT:
|
case TSDB_DATA_TYPE_UTINYINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(uint8_t);
|
pBase[bindIdx].buffer_length = sizeof(uint8_t);
|
||||||
data->pBind[bindIdx].buffer = data->utinyData + rowIdx;
|
pBase[bindIdx].buffer = data->utinyData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_USMALLINT:
|
case TSDB_DATA_TYPE_USMALLINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(uint16_t);
|
pBase[bindIdx].buffer_length = sizeof(uint16_t);
|
||||||
data->pBind[bindIdx].buffer = data->usmallData + rowIdx;
|
pBase[bindIdx].buffer = data->usmallData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_UINT:
|
case TSDB_DATA_TYPE_UINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(uint32_t);
|
pBase[bindIdx].buffer_length = sizeof(uint32_t);
|
||||||
data->pBind[bindIdx].buffer = data->uintData + rowIdx;
|
pBase[bindIdx].buffer = data->uintData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
case TSDB_DATA_TYPE_UBIGINT:
|
case TSDB_DATA_TYPE_UBIGINT:
|
||||||
data->pBind[bindIdx].buffer_length = sizeof(uint64_t);
|
pBase[bindIdx].buffer_length = sizeof(uint64_t);
|
||||||
data->pBind[bindIdx].buffer = data->ubigData + rowIdx;
|
pBase[bindIdx].buffer = data->ubigData + rowIdx;
|
||||||
data->pBind[bindIdx].length = NULL;
|
pBase[bindIdx].length = NULL;
|
||||||
data->pBind[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
pBase[bindIdx].is_null = data->isNull ? (data->isNull + rowIdx) : NULL;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printf("!!!invalid col type:%d", dataType);
|
printf("!!!invalid col type:%d", dataType);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
data->pBind[bindIdx].buffer_type = dataType;
|
pBase[bindIdx].buffer_type = dataType;
|
||||||
data->pBind[bindIdx].num = gCurCase->bindRowNum;
|
pBase[bindIdx].num = gCurCase->bindRowNum;
|
||||||
|
|
||||||
|
if (bType == BP_BIND_TAG) {
|
||||||
|
pBase[bindIdx].num = 1;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -694,6 +855,7 @@ int32_t prepareInsertData(BindData *data) {
|
||||||
data->colTypes = taosMemoryCalloc(30, sizeof(int32_t));
|
data->colTypes = taosMemoryCalloc(30, sizeof(int32_t));
|
||||||
data->sql = taosMemoryCalloc(1, 1024);
|
data->sql = taosMemoryCalloc(1, 1024);
|
||||||
data->pBind = taosMemoryCalloc((allRowNum/gCurCase->bindRowNum)*gCurCase->bindColNum, sizeof(TAOS_MULTI_BIND));
|
data->pBind = taosMemoryCalloc((allRowNum/gCurCase->bindRowNum)*gCurCase->bindColNum, sizeof(TAOS_MULTI_BIND));
|
||||||
|
data->pTags = taosMemoryCalloc(gCurCase->tblNum*gCurCase->bindTagNum, sizeof(TAOS_MULTI_BIND));
|
||||||
data->tsData = taosMemoryMalloc(allRowNum * sizeof(int64_t));
|
data->tsData = taosMemoryMalloc(allRowNum * sizeof(int64_t));
|
||||||
data->boolData = taosMemoryMalloc(allRowNum * sizeof(bool));
|
data->boolData = taosMemoryMalloc(allRowNum * sizeof(bool));
|
||||||
data->tinyData = taosMemoryMalloc(allRowNum * sizeof(int8_t));
|
data->tinyData = taosMemoryMalloc(allRowNum * sizeof(int8_t));
|
||||||
|
@ -734,10 +896,17 @@ int32_t prepareInsertData(BindData *data) {
|
||||||
|
|
||||||
for (int b = 0; b < (allRowNum/gCurCase->bindRowNum); b++) {
|
for (int b = 0; b < (allRowNum/gCurCase->bindRowNum); b++) {
|
||||||
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
||||||
prepareColData(data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
prepareColData(BP_BIND_COL, data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (int b = 0; b < gCurCase->tblNum; b++) {
|
||||||
|
for (int c = 0; c < gCurCase->bindTagNum; ++c) {
|
||||||
|
prepareColData(BP_BIND_TAG, data, b*gCurCase->bindTagNum+c, b, c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
generateInsertSQL(data);
|
generateInsertSQL(data);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -791,11 +960,11 @@ int32_t prepareQueryCondData(BindData *data, int32_t tblIdx) {
|
||||||
|
|
||||||
for (int b = 0; b < bindNum; b++) {
|
for (int b = 0; b < bindNum; b++) {
|
||||||
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
||||||
prepareColData(data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
prepareColData(BP_BIND_COL, data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
generateQuerySQL(data, tblIdx);
|
generateQueryCondSQL(data, tblIdx);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -849,7 +1018,7 @@ int32_t prepareQueryMiscData(BindData *data, int32_t tblIdx) {
|
||||||
|
|
||||||
for (int b = 0; b < bindNum; b++) {
|
for (int b = 0; b < bindNum; b++) {
|
||||||
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
for (int c = 0; c < gCurCase->bindColNum; ++c) {
|
||||||
prepareColData(data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
prepareColData(BP_BIND_COL, data, b*gCurCase->bindColNum+c, b*gCurCase->bindRowNum, c);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1099,6 +1268,15 @@ void bpCheckQueryResult(TAOS_STMT *stmt, TAOS *taos, char *stmtSql, TAOS_MULTI_B
|
||||||
printf("***sql res num match stmt res num %d\n", stmtResNum);
|
printf("***sql res num match stmt res num %d\n", stmtResNum);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int32_t bpSetTableNameTags(BindData *data, int32_t tblIdx, char *tblName, TAOS_STMT *stmt) {
|
||||||
|
if (gCurCase->bindTagNum > 0) {
|
||||||
|
return taos_stmt_set_tbname_tags(stmt, tblName, data->pTags + tblIdx * gCurCase->bindTagNum);
|
||||||
|
} else {
|
||||||
|
return taos_stmt_set_tbname(stmt, tblName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* prepare [settbname [bind add]] exec */
|
/* prepare [settbname [bind add]] exec */
|
||||||
int insertMBSETest1(TAOS_STMT *stmt, TAOS *taos) {
|
int insertMBSETest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
BindData data = {0};
|
BindData data = {0};
|
||||||
|
@ -1117,7 +1295,7 @@ int insertMBSETest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1174,7 +1352,7 @@ int insertMBSETest2(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1227,7 +1405,7 @@ int insertMBMETest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1281,7 +1459,7 @@ int insertMBMETest2(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1335,7 +1513,7 @@ int insertMBMETest3(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1350,7 +1528,7 @@ int insertMBMETest3(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1402,7 +1580,7 @@ int insertMBMETest4(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1458,7 +1636,7 @@ int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
if (gCurCase->tblNum > 1) {
|
if (gCurCase->tblNum > 1) {
|
||||||
char buf[32];
|
char buf[32];
|
||||||
sprintf(buf, "t%d", t);
|
sprintf(buf, "t%d", t);
|
||||||
code = taos_stmt_set_tbname(stmt, buf);
|
code = bpSetTableNameTags(&data, t, buf, stmt);
|
||||||
if (code != 0){
|
if (code != 0){
|
||||||
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
printf("!!!taos_stmt_set_tbname error:%s\n", taos_stmt_errstr(stmt));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
@ -1502,6 +1680,74 @@ int insertMPMETest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* [prepare [settbnametag [bind add] exec]] */
|
||||||
|
int insertAUTOTest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
|
int32_t loop = 0;
|
||||||
|
|
||||||
|
while (gCurCase->bindTagNum > 0 && gCurCase->bindColNum > 0) {
|
||||||
|
BindData data = {0};
|
||||||
|
prepareInsertData(&data);
|
||||||
|
|
||||||
|
int code = taos_stmt_prepare(stmt, data.sql, 0);
|
||||||
|
if (code != 0){
|
||||||
|
printf("!!!failed to execute taos_stmt_prepare. error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckIsInsert(stmt, 1);
|
||||||
|
|
||||||
|
int32_t bindTimes = gCurCase->rowNum/gCurCase->bindRowNum;
|
||||||
|
for (int32_t t = 0; t< gCurCase->tblNum; ++t) {
|
||||||
|
if (gCurCase->tblNum > 1) {
|
||||||
|
char buf[32];
|
||||||
|
sprintf(buf, "t%d", t);
|
||||||
|
code = taos_stmt_set_tbname_tags(stmt, buf, data.pTags + t * gCurCase->bindTagNum);
|
||||||
|
if (code != 0){
|
||||||
|
printf("!!!taos_stmt_set_tbname_tags error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gCaseCtrl.checkParamNum) {
|
||||||
|
bpCheckParamNum(stmt);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int32_t b = 0; b <bindTimes; ++b) {
|
||||||
|
if (bpBindParam(stmt, data.pBind + t*bindTimes*gCurCase->bindColNum + b*gCurCase->bindColNum)) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (taos_stmt_add_batch(stmt)) {
|
||||||
|
printf("!!!taos_stmt_add_batch error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (taos_stmt_execute(stmt) != 0) {
|
||||||
|
printf("!!!taos_stmt_execute error:%s\n", taos_stmt_errstr(stmt));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckIsInsert(stmt, 1);
|
||||||
|
|
||||||
|
destroyData(&data);
|
||||||
|
|
||||||
|
gCurCase->bindColNum -= 2;
|
||||||
|
gCurCase->bindTagNum -= 2;
|
||||||
|
gCurCase->fullCol = false;
|
||||||
|
loop++;
|
||||||
|
}
|
||||||
|
|
||||||
|
bpCheckAffectedRows(stmt, loop);
|
||||||
|
|
||||||
|
gExecLoopTimes = loop;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* select * from table */
|
/* select * from table */
|
||||||
int querySUBTTest1(TAOS_STMT *stmt, TAOS *taos) {
|
int querySUBTTest1(TAOS_STMT *stmt, TAOS *taos) {
|
||||||
BindData data = {0};
|
BindData data = {0};
|
||||||
|
@ -2911,63 +3157,6 @@ int sql_s_perf1(TAOS *taos) {
|
||||||
void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *colList, bool stable) {
|
void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *colList, bool stable) {
|
||||||
int32_t blen = 0;
|
int32_t blen = 0;
|
||||||
blen = sprintf(buf, "create table %s%d ", (stable ? bpStbPrefix : bpTbPrefix), tblIdx);
|
blen = sprintf(buf, "create table %s%d ", (stable ? bpStbPrefix : bpTbPrefix), tblIdx);
|
||||||
if (stable) {
|
|
||||||
blen += sprintf(buf + blen, "tags (");
|
|
||||||
for (int c = 0; c < colNum; ++c) {
|
|
||||||
if (c > 0) {
|
|
||||||
blen += sprintf(buf + blen, ",");
|
|
||||||
}
|
|
||||||
switch (colList[c]) {
|
|
||||||
case TSDB_DATA_TYPE_BOOL:
|
|
||||||
blen += sprintf(buf + blen, "tbooldata bool");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_TINYINT:
|
|
||||||
blen += sprintf(buf + blen, "ttinydata tinyint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_SMALLINT:
|
|
||||||
blen += sprintf(buf + blen, "tsmalldata smallint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_INT:
|
|
||||||
blen += sprintf(buf + blen, "tintdata int");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_BIGINT:
|
|
||||||
blen += sprintf(buf + blen, "tbigdata bigint");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_FLOAT:
|
|
||||||
blen += sprintf(buf + blen, "tfloatdata float");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_DOUBLE:
|
|
||||||
blen += sprintf(buf + blen, "tdoubledata double");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_VARCHAR:
|
|
||||||
blen += sprintf(buf + blen, "tbinarydata binary(%d)", gVarCharSize);
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_TIMESTAMP:
|
|
||||||
blen += sprintf(buf + blen, "tts ts");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_NCHAR:
|
|
||||||
blen += sprintf(buf + blen, "tnchardata nchar(%d)", gVarCharSize);
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UTINYINT:
|
|
||||||
blen += sprintf(buf + blen, "tutinydata tinyint unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_USMALLINT:
|
|
||||||
blen += sprintf(buf + blen, "tusmalldata smallint unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UINT:
|
|
||||||
blen += sprintf(buf + blen, "tuintdata int unsigned");
|
|
||||||
break;
|
|
||||||
case TSDB_DATA_TYPE_UBIGINT:
|
|
||||||
blen += sprintf(buf + blen, "tubigdata bigint unsigned");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
printf("invalid col type:%d", colList[c]);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
blen += sprintf(buf + blen, ")");
|
|
||||||
}
|
|
||||||
|
|
||||||
blen += sprintf(buf + blen, " (");
|
blen += sprintf(buf + blen, " (");
|
||||||
|
|
||||||
|
@ -3027,6 +3216,64 @@ void generateCreateTableSQL(char *buf, int32_t tblIdx, int32_t colNum, int32_t *
|
||||||
|
|
||||||
blen += sprintf(buf + blen, ")");
|
blen += sprintf(buf + blen, ")");
|
||||||
|
|
||||||
|
if (stable) {
|
||||||
|
blen += sprintf(buf + blen, "tags (");
|
||||||
|
for (int c = 0; c < colNum; ++c) {
|
||||||
|
if (c > 0) {
|
||||||
|
blen += sprintf(buf + blen, ",");
|
||||||
|
}
|
||||||
|
switch (colList[c]) {
|
||||||
|
case TSDB_DATA_TYPE_BOOL:
|
||||||
|
blen += sprintf(buf + blen, "tbooldata bool");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TINYINT:
|
||||||
|
blen += sprintf(buf + blen, "ttinydata tinyint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_SMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "tsmalldata smallint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_INT:
|
||||||
|
blen += sprintf(buf + blen, "tintdata int");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_BIGINT:
|
||||||
|
blen += sprintf(buf + blen, "tbigdata bigint");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_FLOAT:
|
||||||
|
blen += sprintf(buf + blen, "tfloatdata float");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_DOUBLE:
|
||||||
|
blen += sprintf(buf + blen, "tdoubledata double");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_VARCHAR:
|
||||||
|
blen += sprintf(buf + blen, "tbinarydata binary(%d)", gVarCharSize);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_TIMESTAMP:
|
||||||
|
blen += sprintf(buf + blen, "tts timestamp");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_NCHAR:
|
||||||
|
blen += sprintf(buf + blen, "tnchardata nchar(%d)", gVarCharSize);
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UTINYINT:
|
||||||
|
blen += sprintf(buf + blen, "tutinydata tinyint unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_USMALLINT:
|
||||||
|
blen += sprintf(buf + blen, "tusmalldata smallint unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UINT:
|
||||||
|
blen += sprintf(buf + blen, "tuintdata int unsigned");
|
||||||
|
break;
|
||||||
|
case TSDB_DATA_TYPE_UBIGINT:
|
||||||
|
blen += sprintf(buf + blen, "tubigdata bigint unsigned");
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("invalid col type:%d", colList[c]);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
blen += sprintf(buf + blen, ")");
|
||||||
|
}
|
||||||
|
|
||||||
if (gCaseCtrl.printCreateTblSql) {
|
if (gCaseCtrl.printCreateTblSql) {
|
||||||
printf("\tCreate Table SQL:%s\n", buf);
|
printf("\tCreate Table SQL:%s\n", buf);
|
||||||
}
|
}
|
||||||
|
@ -3067,7 +3314,7 @@ void prepare(TAOS *taos, int32_t colNum, int32_t *colList, int prepareStb) {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
generateCreateTableSQL(buf, 1, colNum, colList, true);
|
generateCreateTableSQL(buf, bpDefaultStbId, colNum, colList, true);
|
||||||
|
|
||||||
result = taos_query(taos, buf);
|
result = taos_query(taos, buf);
|
||||||
code = taos_errno(result);
|
code = taos_errno(result);
|
||||||
|
@ -3111,16 +3358,33 @@ int32_t runCase(TAOS *taos, int32_t caseIdx, int32_t caseRunIdx, bool silent) {
|
||||||
gCurCase->rowNum = gCaseCtrl.rowNum;
|
gCurCase->rowNum = gCaseCtrl.rowNum;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (gCaseCtrl.autoCreateTbl) {
|
||||||
|
if (gCurCase->testType == TTYPE_INSERT && gCurCase->tblNum > 1) {
|
||||||
|
gCurCase->autoCreateTbl = true;
|
||||||
|
if (gCurCase->bindTagNum <= 0) {
|
||||||
|
gCurCase->bindTagNum = gCurCase->colNum;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (gCurCase->fullCol) {
|
if (gCurCase->fullCol) {
|
||||||
gCurCase->bindColNum = gCurCase->colNum;
|
gCurCase->bindColNum = gCurCase->colNum;
|
||||||
|
if (gCurCase->autoCreateTbl) {
|
||||||
|
gCurCase->bindTagNum = gCurCase->colNum;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
gCurCase->bindNullNum = gCaseCtrl.bindNullNum;
|
gCurCase->bindNullNum = gCaseCtrl.bindNullNum;
|
||||||
gCurCase->prepareStb = gCaseCtrl.prepareStb;
|
|
||||||
if (gCaseCtrl.bindColNum) {
|
if (gCaseCtrl.bindColNum) {
|
||||||
gCurCase->bindColNum = gCaseCtrl.bindColNum;
|
gCurCase->bindColNum = gCaseCtrl.bindColNum;
|
||||||
gCurCase->fullCol = false;
|
gCurCase->fullCol = false;
|
||||||
}
|
}
|
||||||
|
if (gCaseCtrl.bindTagNum) {
|
||||||
|
gCurCase->bindTagNum = gCaseCtrl.bindTagNum;
|
||||||
|
gCurCase->fullCol = false;
|
||||||
|
}
|
||||||
if (gCaseCtrl.bindRowNum) {
|
if (gCaseCtrl.bindRowNum) {
|
||||||
gCurCase->bindRowNum = gCaseCtrl.bindRowNum;
|
gCurCase->bindRowNum = gCaseCtrl.bindRowNum;
|
||||||
}
|
}
|
||||||
|
@ -3128,6 +3392,10 @@ int32_t runCase(TAOS *taos, int32_t caseIdx, int32_t caseRunIdx, bool silent) {
|
||||||
gCurCase->bindColNum = gCaseCtrl.bindColTypeNum;
|
gCurCase->bindColNum = gCaseCtrl.bindColTypeNum;
|
||||||
gCurCase->fullCol = false;
|
gCurCase->fullCol = false;
|
||||||
}
|
}
|
||||||
|
if (gCaseCtrl.bindTagTypeNum) {
|
||||||
|
gCurCase->bindTagNum = gCaseCtrl.bindTagTypeNum;
|
||||||
|
gCurCase->fullCol = false;
|
||||||
|
}
|
||||||
|
|
||||||
if (!silent) {
|
if (!silent) {
|
||||||
printf("* Case %d - [%s]%s Begin *\n", caseRunIdx, gCaseCtrl.caseCatalog, gCurCase->caseDesc);
|
printf("* Case %d - [%s]%s Begin *\n", caseRunIdx, gCaseCtrl.caseCatalog, gCurCase->caseDesc);
|
||||||
|
@ -3136,7 +3404,7 @@ int32_t runCase(TAOS *taos, int32_t caseIdx, int32_t caseRunIdx, bool silent) {
|
||||||
totalUs = 0;
|
totalUs = 0;
|
||||||
for (int32_t n = 0; n < gCurCase->runTimes; ++n) {
|
for (int32_t n = 0; n < gCurCase->runTimes; ++n) {
|
||||||
if (gCurCase->preCaseIdx < 0) {
|
if (gCurCase->preCaseIdx < 0) {
|
||||||
prepare(taos, gCurCase->colNum, gCurCase->colList, gCurCase->prepareStb);
|
prepare(taos, gCurCase->colNum, gCurCase->colList, gCurCase->autoCreateTbl);
|
||||||
}
|
}
|
||||||
|
|
||||||
beginUs = taosGetTimestampUs();
|
beginUs = taosGetTimestampUs();
|
||||||
|
@ -3197,10 +3465,18 @@ void* runCaseList(TAOS *taos) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void runAll(TAOS *taos) {
|
void runAll(TAOS *taos) {
|
||||||
|
/*
|
||||||
strcpy(gCaseCtrl.caseCatalog, "Normal Test");
|
strcpy(gCaseCtrl.caseCatalog, "Normal Test");
|
||||||
printf("%s Begin\n", gCaseCtrl.caseCatalog);
|
printf("%s Begin\n", gCaseCtrl.caseCatalog);
|
||||||
runCaseList(taos);
|
runCaseList(taos);
|
||||||
|
*/
|
||||||
|
strcpy(gCaseCtrl.caseCatalog, "Auto Create Table Test");
|
||||||
|
gCaseCtrl.autoCreateTbl = true;
|
||||||
|
printf("%s Begin\n", gCaseCtrl.caseCatalog);
|
||||||
|
runCaseList(taos);
|
||||||
|
gCaseCtrl.autoCreateTbl = false;
|
||||||
|
|
||||||
|
/*
|
||||||
strcpy(gCaseCtrl.caseCatalog, "Null Test");
|
strcpy(gCaseCtrl.caseCatalog, "Null Test");
|
||||||
printf("%s Begin\n", gCaseCtrl.caseCatalog);
|
printf("%s Begin\n", gCaseCtrl.caseCatalog);
|
||||||
gCaseCtrl.bindNullNum = 1;
|
gCaseCtrl.bindNullNum = 1;
|
||||||
|
@ -3244,6 +3520,7 @@ void runAll(TAOS *taos) {
|
||||||
gCaseCtrl.bindColTypeNum = tListLen(bindColTypeList);
|
gCaseCtrl.bindColTypeNum = tListLen(bindColTypeList);
|
||||||
gCaseCtrl.bindColTypeList = bindColTypeList;
|
gCaseCtrl.bindColTypeList = bindColTypeList;
|
||||||
runCaseList(taos);
|
runCaseList(taos);
|
||||||
|
*/
|
||||||
|
|
||||||
printf("All Test End\n");
|
printf("All Test End\n");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue