• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

taosdata / TDengine / #4506

15 Jul 2025 12:33AM UTC coverage: 62.026% (-0.7%) from 62.706%
#4506

push

travis-ci

web-flow
docs: update stream docs (#31874)

155391 of 320094 branches covered (48.55%)

Branch coverage included in aggregate %.

240721 of 318525 relevant lines covered (75.57%)

6529048.03 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

62.88
/source/dnode/mnode/impl/src/mndIndex.c
1
/*
2
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
3
 *
4
 * This program is free software: you can use, redistribute, and/or modify
5
 * it under the terms of the GNU Affero General Public License, version 3
6
 * or later ("AGPL"), as published by the Free Software Foundation.
7
 *
8
 * This program is distributed in the hope that it will be useful, but WITHOUT
9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10
 * FITNESS FOR A PARTICULAR PURPOSE.
11
 *
12
 * You should have received a copy of the GNU Affero General Public License
13
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
14
 */
15

16
#define _DEFAULT_SOURCE
17
#include "mndIndex.h"
18
#include "mndDb.h"
19
#include "mndDnode.h"
20
#include "mndIndexComm.h"
21
#include "mndInfoSchema.h"
22
#include "mndMnode.h"
23
#include "mndPrivilege.h"
24
#include "mndScheduler.h"
25
#include "mndShow.h"
26
#include "mndStb.h"
27
#include "mndStream.h"
28
#include "mndTrans.h"
29
#include "mndUser.h"
30
#include "mndVgroup.h"
31
#include "parser.h"
32
#include "tname.h"
33

34
#define TSDB_IDX_VER_NUMBER   1
35
#define TSDB_IDX_RESERVE_SIZE 64
36

37
static SSdbRaw *mndIdxActionEncode(SIdxObj *pSma);
38
static SSdbRow *mndIdxActionDecode(SSdbRaw *pRaw);
39
static int32_t  mndIdxActionInsert(SSdb *pSdb, SIdxObj *pIdx);
40
static int32_t  mndIdxActionDelete(SSdb *pSdb, SIdxObj *pIdx);
41
static int32_t  mndIdxActionUpdate(SSdb *pSdb, SIdxObj *pOld, SIdxObj *pNew);
42
static int32_t  mndProcessCreateIdxReq(SRpcMsg *pReq);
43
// static int32_t  mndProcessDropIdxReq(SRpcMsg *pReq);
44
static int32_t mndProcessGetIdxReq(SRpcMsg *pReq);
45
static int32_t mndProcessGetTbIdxReq(SRpcMsg *pReq);
46
// static int32_t mndRetrieveIdx(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock *pBlock, int32_t rows);
47
//  static void    mndCancelGetNextIdx(SMnode *pMnode, void *pIter);
48
static void mndDestroyIdxObj(SIdxObj *pIdxObj);
49

50
static int32_t mndAddIndex(SMnode *pMnode, SRpcMsg *pReq, SCreateTagIndexReq *req, SDbObj *pDb, SStbObj *pStb);
51

52
int32_t mndInitIdx(SMnode *pMnode) {
2,477✔
53
  SSdbTable table = {
2,477✔
54
      .sdbType = SDB_IDX,
55
      .keyType = SDB_KEY_BINARY,
56
      .encodeFp = (SdbEncodeFp)mndIdxActionEncode,
57
      .decodeFp = (SdbDecodeFp)mndIdxActionDecode,
58
      .insertFp = (SdbInsertFp)mndIdxActionInsert,
59
      .updateFp = (SdbUpdateFp)mndIdxActionUpdate,
60
      .deleteFp = (SdbDeleteFp)mndIdxActionDelete,
61
  };
62

63
  mndSetMsgHandle(pMnode, TDMT_MND_CREATE_INDEX, mndProcessCreateIdxReq);
2,477✔
64
  // mndSetMsgHandle(pMnode, TDMT_MND_DROP_INDEX, mndProcessDropIdxReq);
65

66
  mndSetMsgHandle(pMnode, TDMT_VND_CREATE_INDEX_RSP, mndTransProcessRsp);
2,477✔
67
  mndSetMsgHandle(pMnode, TDMT_VND_DROP_INDEX_RSP, mndTransProcessRsp);
2,477✔
68

69
  // mndSetMsgHandle(pMnode, TDMT_MND_CREATE_SMA, mndProcessCreateIdxReq);
70
  // mndSetMsgHandle(pMnode, TDMT_MND_DROP_SMA, mndProcessDropIdxReq);
71
  // mndSetMsgHandle(pMnode, TDMT_VND_CREATE_SMA_RSP, mndTransProcessRsp);
72
  // mndSetMsgHandle(pMnode, TDMT_VND_DROP_SMA_RSP, mndTransProcessRsp);
73
  // mndSetMsgHandle(pMnode, TDMT_MND_GET_INDEX, mndProcessGetIdxReq);
74
  // mndSetMsgHandle(pMnode, TDMT_MND_GET_TABLE_INDEX, mndProcessGetTbIdxReq);
75

76
  // type same with sma
77
  // mndAddShowRetrieveHandle(pMnode, TSDB_MGMT_TABLE_INDEX, mndRetrieveIdx);
78
  // mndAddShowFreeIterHandle(pMnode, TSDB_MGMT_TABLE_INDEX, mndCancelGetNextIdx);
79
  return sdbSetTable(pMnode->pSdb, table);
2,477✔
80
}
81

82
static int32_t mndFindSuperTableTagId(const SStbObj *pStb, const char *tagName, int8_t *hasIdx) {
48✔
83
  for (int32_t tag = 0; tag < pStb->numOfTags; tag++) {
104!
84
    if (taosStrcasecmp(pStb->pTags[tag].name, tagName) == 0) {
104✔
85
      if (IS_IDX_ON(&pStb->pTags[tag])) {
48✔
86
        *hasIdx = 1;
20✔
87
      }
88
      return tag;
48✔
89
    }
90
  }
91

92
  return TSDB_CODE_MND_TAG_NOT_EXIST;
×
93
}
94

95
int mndSetCreateIdxRedoActions(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SStbObj *pStb, SIdxObj *pIdx) {
14✔
96
  int32_t code = 0;
14✔
97
  SSdb   *pSdb = pMnode->pSdb;
14✔
98
  SVgObj *pVgroup = NULL;
14✔
99
  void   *pIter = NULL;
14✔
100
  int32_t contLen;
101

102
  while (1) {
26✔
103
    pIter = sdbFetch(pSdb, SDB_VGROUP, pIter, (void **)&pVgroup);
40✔
104
    if (pIter == NULL) break;
40✔
105
    if (!mndVgroupInDb(pVgroup, pDb->uid)) {
26!
106
      sdbRelease(pSdb, pVgroup);
×
107
      continue;
×
108
    }
109

110
    void *pReq = mndBuildVCreateStbReq(pMnode, pVgroup, pStb, &contLen, NULL, 0);
26✔
111
    if (pReq == NULL) {
26!
112
      sdbCancelFetch(pSdb, pIter);
×
113
      sdbRelease(pSdb, pVgroup);
×
114
      code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
115
      if (terrno != 0) code = terrno;
×
116
      TAOS_RETURN(code);
×
117
    }
118
    STransAction action = {0};
26✔
119
    action.epSet = mndGetVgroupEpset(pMnode, pVgroup);
26✔
120
    action.pCont = pReq;
26✔
121
    action.contLen = contLen;
26✔
122
    action.msgType = TDMT_VND_CREATE_INDEX;
26✔
123
    if ((code = mndTransAppendRedoAction(pTrans, &action)) != 0) {
26!
124
      taosMemoryFree(pReq);
×
125
      sdbCancelFetch(pSdb, pIter);
×
126
      sdbRelease(pSdb, pVgroup);
×
127
      TAOS_RETURN(code);
×
128
    }
129
    sdbRelease(pSdb, pVgroup);
26✔
130
  }
131

132
  return 0;
14✔
133
}
134
static void *mndBuildDropIdxReq(SMnode *pMnode, SVgObj *pVgroup, SStbObj *pStbObj, SIdxObj *pIdx, int32_t *contLen) {
16✔
135
  int32_t len = 0;
16✔
136

137
  SDropIndexReq req = {0};
16✔
138
  memcpy(req.colName, pIdx->colName, sizeof(pIdx->colName));
16✔
139
  memcpy(req.stb, pIdx->stb, sizeof(pIdx->stb));
16✔
140
  req.dbUid = pIdx->dbUid;
16✔
141
  req.stbUid = pIdx->stbUid;
16✔
142

143
  mInfo("idx: %s start to build drop index req", pIdx->name);
16!
144

145
  len = tSerializeSDropIdxReq(NULL, 0, &req);
16✔
146
  if (len < 0) {
16!
147
    goto _err;
×
148
  }
149

150
  len += sizeof(SMsgHead);
16✔
151
  SMsgHead *pHead = taosMemoryCalloc(1, len);
16!
152
  if (pHead == NULL) {
16!
153
    terrno = TSDB_CODE_OUT_OF_MEMORY;
×
154
    goto _err;
×
155
  }
156

157
  pHead->contLen = htonl(len);
16✔
158
  pHead->vgId = htonl(pVgroup->vgId);
16✔
159

160
  void   *pBuf = POINTER_SHIFT(pHead, sizeof(SMsgHead));
16✔
161
  int32_t ret = 0;
16✔
162
  if ((ret = tSerializeSDropIdxReq(pBuf, len - sizeof(SMsgHead), &req)) < 0) {
16!
163
    terrno = ret;
×
164
    return NULL;
×
165
  }
166
  *contLen = len;
16✔
167
  return pHead;
16✔
168
_err:
×
169

170
  return NULL;
×
171
}
172
int mndSetDropIdxRedoActions(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SStbObj *pStb, SIdxObj *pIdx) {
8✔
173
  int32_t code = 0;
8✔
174
  SSdb   *pSdb = pMnode->pSdb;
8✔
175
  SVgObj *pVgroup = NULL;
8✔
176
  void   *pIter = NULL;
8✔
177
  int32_t contLen;
178

179
  while (1) {
16✔
180
    pIter = sdbFetch(pSdb, SDB_VGROUP, pIter, (void **)&pVgroup);
24✔
181
    if (pIter == NULL) break;
24✔
182
    if (!mndVgroupInDb(pVgroup, pDb->uid)) {
16!
183
      sdbRelease(pSdb, pVgroup);
×
184
      continue;
×
185
    }
186

187
    int32_t len;
188
    void   *pReq = mndBuildDropIdxReq(pMnode, pVgroup, pStb, pIdx, &len);
16✔
189
    if (pReq == NULL) {
16!
190
      sdbCancelFetch(pSdb, pIter);
×
191
      sdbRelease(pSdb, pVgroup);
×
192
      code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
193
      if (terrno != 0) code = terrno;
×
194
      return code;
×
195
    }
196
    STransAction action = {0};
16✔
197
    action.epSet = mndGetVgroupEpset(pMnode, pVgroup);
16✔
198
    action.pCont = pReq;
16✔
199
    action.contLen = len;
16✔
200
    action.msgType = TDMT_VND_DROP_INDEX;
16✔
201
    if ((code = mndTransAppendRedoAction(pTrans, &action)) != 0) {
16!
202
      taosMemoryFree(pReq);
×
203
      sdbCancelFetch(pSdb, pIter);
×
204
      sdbRelease(pSdb, pVgroup);
×
205
      return code;
×
206
    }
207
    sdbRelease(pSdb, pVgroup);
16✔
208
  }
209

210
  TAOS_RETURN(code);
8✔
211
}
212

213
void mndCleanupIdx(SMnode *pMnode) {
2,476✔
214
  // do nothing
215
  return;
2,476✔
216
}
217

218
static SSdbRaw *mndIdxActionEncode(SIdxObj *pIdx) {
19,010✔
219
  int32_t code = 0;
19,010✔
220
  int32_t lino = 0;
19,010✔
221
  terrno = TSDB_CODE_OUT_OF_MEMORY;
19,010✔
222

223
  // int32_t size =
224
  //     sizeof(SSmaObj) + pSma->exprLen + pSma->tagsFilterLen + pSma->sqlLen + pSma->astLen + TSDB_IDX_RESERVE_SIZE;
225
  int32_t size = sizeof(SIdxObj) + TSDB_IDX_RESERVE_SIZE;
19,010✔
226

227
  SSdbRaw *pRaw = sdbAllocRaw(SDB_IDX, TSDB_IDX_VER_NUMBER, size);
19,010✔
228
  if (pRaw == NULL) goto _OVER;
19,010!
229

230
  int32_t dataPos = 0;
19,010✔
231
  SDB_SET_BINARY(pRaw, dataPos, pIdx->name, TSDB_TABLE_FNAME_LEN, _OVER)
19,010!
232
  SDB_SET_BINARY(pRaw, dataPos, pIdx->stb, TSDB_TABLE_FNAME_LEN, _OVER)
19,010!
233
  SDB_SET_BINARY(pRaw, dataPos, pIdx->db, TSDB_DB_FNAME_LEN, _OVER)
19,010!
234
  SDB_SET_BINARY(pRaw, dataPos, pIdx->dstTbName, TSDB_DB_FNAME_LEN, _OVER)
19,010!
235
  SDB_SET_BINARY(pRaw, dataPos, pIdx->colName, TSDB_COL_NAME_LEN, _OVER)
19,010!
236
  SDB_SET_INT64(pRaw, dataPos, pIdx->createdTime, _OVER)
19,010!
237
  SDB_SET_INT64(pRaw, dataPos, pIdx->uid, _OVER)
19,010!
238
  SDB_SET_INT64(pRaw, dataPos, pIdx->stbUid, _OVER)
19,010!
239
  SDB_SET_INT64(pRaw, dataPos, pIdx->dbUid, _OVER)
19,010!
240

241
  SDB_SET_RESERVE(pRaw, dataPos, TSDB_IDX_RESERVE_SIZE, _OVER)
19,010!
242
  SDB_SET_DATALEN(pRaw, dataPos, _OVER)
19,010!
243

244
  terrno = 0;
19,010✔
245

246
_OVER:
19,010✔
247
  if (terrno != 0) {
19,010!
248
    mError("idx:%s, failed to encode to raw:%p since %s", pIdx->name, pRaw, terrstr());
×
249
    sdbFreeRaw(pRaw);
×
250
    return NULL;
×
251
  }
252

253
  mTrace("idx:%s, encode to raw:%p, row:%p", pIdx->name, pRaw, pIdx);
19,010✔
254
  return pRaw;
19,010✔
255
}
256

257
static SSdbRow *mndIdxActionDecode(SSdbRaw *pRaw) {
13,183✔
258
  int32_t code = 0;
13,183✔
259
  int32_t lino = 0;
13,183✔
260
  terrno = TSDB_CODE_OUT_OF_MEMORY;
13,183✔
261
  SSdbRow *pRow = NULL;
13,183✔
262
  SIdxObj *pIdx = NULL;
13,183✔
263

264
  int8_t sver = 0;
13,183✔
265
  if (sdbGetRawSoftVer(pRaw, &sver) != 0) goto _OVER;
13,183!
266

267
  if (sver != TSDB_IDX_VER_NUMBER) {
13,183!
268
    terrno = TSDB_CODE_SDB_INVALID_DATA_VER;
×
269
    goto _OVER;
×
270
  }
271

272
  pRow = sdbAllocRow(sizeof(SIdxObj));
13,183✔
273
  if (pRow == NULL) goto _OVER;
13,183!
274

275
  pIdx = sdbGetRowObj(pRow);
13,183✔
276
  if (pIdx == NULL) goto _OVER;
13,183!
277

278
  int32_t dataPos = 0;
13,183✔
279

280
  SDB_GET_BINARY(pRaw, dataPos, pIdx->name, TSDB_TABLE_FNAME_LEN, _OVER)
13,183!
281
  SDB_GET_BINARY(pRaw, dataPos, pIdx->stb, TSDB_TABLE_FNAME_LEN, _OVER)
13,183!
282
  SDB_GET_BINARY(pRaw, dataPos, pIdx->db, TSDB_DB_FNAME_LEN, _OVER)
13,183!
283
  SDB_GET_BINARY(pRaw, dataPos, pIdx->dstTbName, TSDB_DB_FNAME_LEN, _OVER)
13,183!
284
  SDB_GET_BINARY(pRaw, dataPos, pIdx->colName, TSDB_COL_NAME_LEN, _OVER)
13,183!
285
  SDB_GET_INT64(pRaw, dataPos, &pIdx->createdTime, _OVER)
13,183!
286
  SDB_GET_INT64(pRaw, dataPos, &pIdx->uid, _OVER)
13,183!
287
  SDB_GET_INT64(pRaw, dataPos, &pIdx->stbUid, _OVER)
13,183!
288
  SDB_GET_INT64(pRaw, dataPos, &pIdx->dbUid, _OVER)
13,183!
289

290
  SDB_GET_RESERVE(pRaw, dataPos, TSDB_IDX_RESERVE_SIZE, _OVER)
13,183!
291

292
  terrno = 0;
13,183✔
293

294
_OVER:
13,183✔
295
  if (terrno != 0) {
13,183!
296
    taosMemoryFree(pRow);
×
297
    return NULL;
×
298
  }
299

300
  mTrace("idx:%s, decode from raw:%p, row:%p", pIdx->name, pRaw, pIdx);
13,183✔
301
  return pRow;
13,183✔
302
}
303

304
static int32_t mndIdxActionInsert(SSdb *pSdb, SIdxObj *pIdx) {
9,944✔
305
  mTrace("idx:%s, perform insert action, row:%p", pIdx->name, pIdx);
9,944✔
306
  return 0;
9,944✔
307
}
308

309
static int32_t mndIdxActionDelete(SSdb *pSdb, SIdxObj *pIdx) {
13,183✔
310
  mTrace("idx:%s, perform delete action, row:%p", pIdx->name, pIdx);
13,183✔
311
  return 0;
13,183✔
312
}
313

314
static int32_t mndIdxActionUpdate(SSdb *pSdb, SIdxObj *pOld, SIdxObj *pNew) {
148✔
315
  // lock no not
316
  if (strncmp(pOld->colName, pNew->colName, TSDB_COL_NAME_LEN) != 0) {
148✔
317
    memcpy(pOld->colName, pNew->colName, sizeof(pNew->colName));
53✔
318
  }
319
  mTrace("idx:%s, perform update action, old row:%p new row:%p", pOld->name, pOld, pNew);
148✔
320
  return 0;
148✔
321
}
322

323
SIdxObj *mndAcquireIdx(SMnode *pMnode, char *idxName) {
×
324
  SSdb    *pSdb = pMnode->pSdb;
×
325
  SIdxObj *pIdx = sdbAcquire(pSdb, SDB_IDX, idxName);
×
326
  if (pIdx == NULL && terrno == TSDB_CODE_SDB_OBJ_NOT_THERE) {
×
327
    terrno = TSDB_CODE_MND_TAG_INDEX_NOT_EXIST;
×
328
  }
329
  return pIdx;
×
330
}
331

332
void mndReleaseIdx(SMnode *pMnode, SIdxObj *pIdx) {
45✔
333
  SSdb *pSdb = pMnode->pSdb;
45✔
334
  sdbRelease(pSdb, pIdx);
45✔
335
}
45✔
336

337
SDbObj *mndAcquireDbByIdx(SMnode *pMnode, const char *idxName) {
8✔
338
  SName name = {0};
8✔
339
  if ((terrno = tNameFromString(&name, idxName, T_NAME_ACCT | T_NAME_DB | T_NAME_TABLE)) < 0) return NULL;
8!
340

341
  char db[TSDB_TABLE_FNAME_LEN] = {0};
8✔
342
  (void)tNameGetFullDbName(&name, db);
8✔
343

344
  return mndAcquireDb(pMnode, db);
8✔
345
}
346

347
int32_t mndSetCreateIdxPrepareLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
14✔
348
  int32_t  code = 0;
14✔
349
  SSdbRaw *pRedoRaw = mndIdxActionEncode(pIdx);
14✔
350
  if (pRedoRaw == NULL) {
14!
351
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
352
    if (terrno != 0) code = terrno;
×
353
    return -1;
×
354
  }
355
  TAOS_CHECK_RETURN(mndTransAppendPrepareLog(pTrans, pRedoRaw));
14!
356
  TAOS_CHECK_RETURN(sdbSetRawStatus(pRedoRaw, SDB_STATUS_CREATING));
14!
357

358
  TAOS_RETURN(code);
14✔
359
}
360

361
int32_t mndSetCreateIdxCommitLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
7,205✔
362
  int32_t  code = 0;
7,205✔
363
  SSdbRaw *pCommitRaw = mndIdxActionEncode(pIdx);
7,205✔
364
  if (pCommitRaw == NULL) {
7,205!
365
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
366
    if (terrno != 0) code = terrno;
×
367
    return -1;
×
368
  }
369
  TAOS_CHECK_RETURN(mndTransAppendCommitlog(pTrans, pCommitRaw));
7,205!
370
  TAOS_CHECK_RETURN(sdbSetRawStatus(pCommitRaw, SDB_STATUS_READY));
7,205!
371

372
  TAOS_RETURN(code);
7,205✔
373
}
374

375
int32_t mndSetAlterIdxPrepareLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
49✔
376
  int32_t  code = 0;
49✔
377
  SSdbRaw *pRedoRaw = mndIdxActionEncode(pIdx);
49✔
378
  if (pRedoRaw == NULL) {
49!
379
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
380
    if (terrno != 0) code = terrno;
×
381
    return -1;
×
382
  }
383
  if ((code = mndTransAppendPrepareLog(pTrans, pRedoRaw)) != 0) {
49!
384
    sdbFreeRaw(pRedoRaw);
×
385
    return -1;
×
386
  }
387
  TAOS_CHECK_RETURN(sdbSetRawStatus(pRedoRaw, SDB_STATUS_READY));
49!
388

389
  TAOS_RETURN(code);
49✔
390
}
391

392
int32_t mndSetAlterIdxCommitLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
49✔
393
  int32_t  code = 0;
49✔
394
  SSdbRaw *pCommitRaw = mndIdxActionEncode(pIdx);
49✔
395
  if (pCommitRaw == NULL) {
49!
396
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
397
    if (terrno != 0) code = terrno;
×
398
    TAOS_RETURN(code);
×
399
  }
400
  if ((code = mndTransAppendCommitlog(pTrans, pCommitRaw)) != 0) {
49!
401
    sdbFreeRaw(pCommitRaw);
×
402
    TAOS_RETURN(code);
×
403
  }
404
  TAOS_CHECK_RETURN(sdbSetRawStatus(pCommitRaw, SDB_STATUS_READY));
49!
405

406
  TAOS_RETURN(code);
49✔
407
}
408

409
static int32_t mndSetCreateIdxVgroupRedoLogs(SMnode *pMnode, STrans *pTrans, SVgObj *pVgroup) {
×
410
  int32_t  code = 0;
×
411
  SSdbRaw *pVgRaw = mndVgroupActionEncode(pVgroup);
×
412
  if (pVgRaw == NULL) {
×
413
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
414
    if (terrno != 0) code = terrno;
×
415
    TAOS_RETURN(code);
×
416
  }
417
  TAOS_CHECK_RETURN(mndTransAppendRedolog(pTrans, pVgRaw));
×
418
  TAOS_CHECK_RETURN(sdbSetRawStatus(pVgRaw, SDB_STATUS_CREATING));
×
419
  TAOS_RETURN(code);
×
420
}
421

422
static int32_t mndSetCreateIdxVgroupCommitLogs(SMnode *pMnode, STrans *pTrans, SVgObj *pVgroup) {
×
423
  int32_t  code = 0;
×
424
  SSdbRaw *pVgRaw = mndVgroupActionEncode(pVgroup);
×
425
  if (pVgRaw == NULL) {
×
426
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
427
    if (terrno != 0) code = terrno;
×
428
    TAOS_RETURN(code);
×
429
  }
430
  TAOS_CHECK_RETURN(mndTransAppendCommitlog(pTrans, pVgRaw));
×
431
  TAOS_CHECK_RETURN(sdbSetRawStatus(pVgRaw, SDB_STATUS_READY));
×
432
  TAOS_RETURN(code);
×
433
}
434

435
// static int32_t mndSetUpdateIdxStbCommitLogs(SMnode *pMnode, STrans *pTrans, SStbObj *pStb) {
436
//   SStbObj stbObj = {0};
437
//   taosRLockLatch(&pStb->lock);
438
//   memcpy(&stbObj, pStb, sizeof(SStbObj));
439
//   taosRUnLockLatch(&pStb->lock);
440
//   stbObj.numOfColumns = 0;
441
//   stbObj.pColumns = NULL;
442
//   stbObj.numOfTags = 0;
443
//  stbObj.pTags = NULL;
444
//   stbObj.numOfFuncs = 0;
445
//   stbObj.pFuncs = NULL;
446
//   stbObj.updateTime = taosGetTimestampMs();
447
//   stbObj.lock = 0;
448
//   stbObj.tagVer++;
449

450
// SSdbRaw *pCommitRaw = mndStbActionEncode(&stbObj);
451
// if (pCommitRaw == NULL) return -1;
452
// if (mndTransAppendCommitlog(pTrans, pCommitRaw) != 0) return -1;
453
// if (sdbSetRawStatus(pCommitRaw, SDB_STATUS_READY) != 0) return -1;
454
//
455
// return 0;
456
//}
457

458
static void mndDestroyIdxObj(SIdxObj *pIdxObj) {
×
459
  if (pIdxObj) {
460
    // do nothing
461
  }
462
}
×
463

464
static int32_t mndProcessCreateIdxReq(SRpcMsg *pReq) {
33✔
465
  SMnode  *pMnode = pReq->info.node;
33✔
466
  int32_t  code = -1;
33✔
467
  SStbObj *pStb = NULL;
33✔
468
  SIdxObj *pIdx = NULL;
33✔
469

470
  SDbObj            *pDb = NULL;
33✔
471
  SCreateTagIndexReq createReq = {0};
33✔
472

473
  TAOS_CHECK_GOTO(tDeserializeSCreateTagIdxReq(pReq->pCont, pReq->contLen, &createReq), NULL, _OVER);
33!
474

475
  mInfo("idx:%s start to create", createReq.idxName);
33!
476
  // if (mndCheckCreateIdxReq(&createReq) != 0) {
477
  //   goto _OVER;
478
  // }
479

480
  pDb = mndAcquireDbByStb(pMnode, createReq.stbName);
33✔
481
  if (pDb == NULL) {
33!
482
    code = TSDB_CODE_MND_DB_NOT_EXIST;
×
483
    if (terrno != 0) code = terrno;
×
484
    goto _OVER;
×
485
  }
486

487
  if(pDb->cfg.isMount) {
33!
488
    code = TSDB_CODE_MND_MOUNT_OBJ_NOT_SUPPORT;
×
489
    goto _OVER;
×
490
  }
491

492
  pStb = mndAcquireStb(pMnode, createReq.stbName);
33✔
493
  if (pStb == NULL) {
33!
494
    mError("idx:%s, failed to create since stb:%s not exist", createReq.idxName, createReq.stbName);
×
495
    code = TSDB_CODE_MND_DB_NOT_EXIST;
×
496
    if (terrno != 0) code = terrno;
×
497
    goto _OVER;
×
498
  }
499
  SSIdx idx = {0};
33✔
500
  if ((code = mndAcquireGlobalIdx(pMnode, createReq.idxName, SDB_IDX, &idx)) == 0) {
33!
501
    pIdx = idx.pIdx;
33✔
502
  } else {
503
    goto _OVER;
×
504
  }
505
  if (pIdx != NULL) {
33✔
506
    code = TSDB_CODE_MND_TAG_INDEX_ALREADY_EXIST;
7✔
507
    goto _OVER;
7✔
508
  }
509

510
  TAOS_CHECK_GOTO(mndCheckDbPrivilege(pMnode, pReq->info.conn.user, MND_OPER_WRITE_DB, pDb), NULL, _OVER);
26!
511

512
  code = mndAddIndex(pMnode, pReq, &createReq, pDb, pStb);
26✔
513
  if (terrno == TSDB_CODE_MND_TAG_INDEX_ALREADY_EXIST || terrno == TSDB_CODE_MND_TAG_NOT_EXIST) {
26!
514
    return terrno;
12✔
515
  } else {
516
    if (code == 0) code = TSDB_CODE_ACTION_IN_PROGRESS;
14!
517
  }
518

519
_OVER:
×
520
  if (code != 0 && code != TSDB_CODE_ACTION_IN_PROGRESS) {
21!
521
    mError("stb:%s, failed to create since %s", createReq.idxName, tstrerror(code));
7!
522
  }
523

524
  mndReleaseStb(pMnode, pStb);
21✔
525
  mndReleaseIdx(pMnode, pIdx);
21✔
526
  mndReleaseDb(pMnode, pDb);
21✔
527

528
  TAOS_RETURN(code);
21✔
529
}
530

531
int32_t mndSetDropIdxPrepareLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
28✔
532
  int32_t  code = 0;
28✔
533
  SSdbRaw *pRedoRaw = mndIdxActionEncode(pIdx);
28✔
534
  if (pRedoRaw == NULL) {
28!
535
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
536
    if (terrno != 0) code = terrno;
×
537
    TAOS_RETURN(code);
×
538
  }
539
  TAOS_CHECK_RETURN(mndTransAppendPrepareLog(pTrans, pRedoRaw));
28!
540
  TAOS_CHECK_RETURN(sdbSetRawStatus(pRedoRaw, SDB_STATUS_DROPPING));
28!
541

542
  TAOS_RETURN(code);
28✔
543
}
544

545
int32_t mndSetDropIdxCommitLogs(SMnode *pMnode, STrans *pTrans, SIdxObj *pIdx) {
3,073✔
546
  int32_t  code = 0;
3,073✔
547
  SSdbRaw *pCommitRaw = mndIdxActionEncode(pIdx);
3,073✔
548
  if (pCommitRaw == NULL) {
3,073!
549
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
550
    if (terrno != 0) code = terrno;
×
551
    TAOS_RETURN(code);
×
552
  }
553
  TAOS_CHECK_RETURN(mndTransAppendCommitlog(pTrans, pCommitRaw));
3,073!
554
  TAOS_CHECK_RETURN(sdbSetRawStatus(pCommitRaw, SDB_STATUS_DROPPED));
3,073!
555

556
  TAOS_RETURN(code);
3,073✔
557
}
558

559
static int32_t mndProcessGetTbIdxReq(SRpcMsg *pReq) {
×
560
  //
561
  return 0;
×
562
}
563

564
int32_t mndRetrieveTagIdx(SRpcMsg *pReq, SShowObj *pShow, SSDataBlock *pBlock, int32_t rows) {
39✔
565
  SMnode  *pMnode = pReq->info.node;
39✔
566
  SSdb    *pSdb = pMnode->pSdb;
39✔
567
  int32_t  numOfRows = 0;
39✔
568
  SIdxObj *pIdx = NULL;
39✔
569
  int32_t  cols = 0;
39✔
570
  int32_t  code = 0;
39✔
571
  int32_t  lino = 0;
39✔
572

573
  SDbObj *pDb = NULL;
39✔
574
  if (strlen(pShow->db) > 0) {
39✔
575
    pDb = mndAcquireDb(pMnode, pShow->db);
25✔
576
    if (pDb == NULL) return 0;
25!
577
  }
578
  SSmaAndTagIter *pIter = pShow->pIter;
39✔
579
  while (numOfRows < rows) {
115!
580
    pIter->pIdxIter = sdbFetch(pSdb, SDB_IDX, pIter->pIdxIter, (void **)&pIdx);
115✔
581
    if (pIter->pIdxIter == NULL) break;
115✔
582

583
    if (NULL != pDb && pIdx->dbUid != pDb->uid) {
76✔
584
      sdbRelease(pSdb, pIdx);
10✔
585
      continue;
10✔
586
    }
587

588
    cols = 0;
66✔
589

590
    SName idxName = {0};
66✔
591
    if ((code = tNameFromString(&idxName, pIdx->name, T_NAME_ACCT | T_NAME_DB | T_NAME_TABLE)) != 0) {
66!
592
      sdbRelease(pSdb, pIdx);
×
593
      goto _OVER;
×
594
    }
595
    char n1[TSDB_TABLE_FNAME_LEN + VARSTR_HEADER_SIZE] = {0};
66✔
596

597
    STR_TO_VARSTR(n1, (char *)tNameGetTableName(&idxName));
66✔
598

599
    char n2[TSDB_DB_FNAME_LEN + VARSTR_HEADER_SIZE] = {0};
66✔
600
    STR_TO_VARSTR(n2, (char *)mndGetDbStr(pIdx->db));
66✔
601

602
    SName stbName = {0};
66✔
603
    if ((code = tNameFromString(&stbName, pIdx->stb, T_NAME_ACCT | T_NAME_DB | T_NAME_TABLE)) != 0) {
66!
604
      sdbRelease(pSdb, pIdx);
×
605
      goto _OVER;
×
606
    }
607
    char n3[TSDB_TABLE_FNAME_LEN + VARSTR_HEADER_SIZE] = {0};
66✔
608
    STR_TO_VARSTR(n3, (char *)tNameGetTableName(&stbName));
66✔
609

610
    SColumnInfoData *pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
611
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)n1, false), pIdx, &lino, _OVER);
66!
612

613
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
614
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)n2, false), pIdx, &lino, _OVER);
66!
615

616
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
617
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)n3, false), pIdx, &lino, _OVER);
66!
618

619
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
620

621
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, NULL, true), pIdx, &lino, _OVER);
66!
622

623
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
624
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)&pIdx->createdTime, false), pIdx, &lino,
66!
625
                        _OVER);
626

627
    char col[TSDB_TABLE_FNAME_LEN + VARSTR_HEADER_SIZE] = {0};
66✔
628
    STR_TO_VARSTR(col, (char *)pIdx->colName);
66✔
629

630
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
631
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)col, false), pIdx, &lino, _OVER);
66!
632

633
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
66✔
634

635
    char tag[TSDB_TABLE_FNAME_LEN + VARSTR_HEADER_SIZE] = {0};
66✔
636
    STR_TO_VARSTR(tag, (char *)"tag_index");
66✔
637
    RETRIEVE_CHECK_GOTO(colDataSetVal(pColInfo, numOfRows, (const char *)tag, false), pIdx, &lino, _OVER);
66!
638

639
    numOfRows++;
66✔
640
    sdbRelease(pSdb, pIdx);
66✔
641
  }
642

643
_OVER:
×
644
  if (code != 0) mError("failed to retrieve at line:%d, since %s", lino, tstrerror(code));
39!
645

646
  mndReleaseDb(pMnode, pDb);
39✔
647
  pShow->numOfRows += numOfRows;
39✔
648
  return numOfRows;
39✔
649
}
650

651
// static void mndCancelGetNextIdx(SMnode *pMnode, void *pIter) {
652
//   SSdb *pSdb = pMnode->pSdb;
653
//
654
//  sdbCancelFetch(pSdb, pIter);
655
//}
656
static int32_t mndCheckIndexReq(SCreateTagIndexReq *pReq) {
×
657
  // impl
658
  return TSDB_CODE_SUCCESS;
×
659
}
660

661
static int32_t mndSetUpdateIdxStbCommitLogs(SMnode *pMnode, STrans *pTrans, SStbObj *pOld, SStbObj *pNew, char *tagName,
22✔
662
                                            int on) {
663
  int32_t code = 0;
22✔
664
  taosRLockLatch(&pOld->lock);
22✔
665
  memcpy(pNew, pOld, sizeof(SStbObj));
22✔
666
  taosRUnLockLatch(&pOld->lock);
22✔
667

668
  pNew->pTags = NULL;
22✔
669
  pNew->pColumns = NULL;
22✔
670
  pNew->pCmpr = NULL;
22✔
671
  pNew->pTags = NULL;
22✔
672
  pNew->pExtSchemas = NULL;
22✔
673
  pNew->updateTime = taosGetTimestampMs();
22✔
674
  pNew->lock = 0;
22✔
675

676
  int8_t  hasIdx = 0;
22✔
677
  int32_t tag = mndFindSuperTableTagId(pOld, tagName, &hasIdx);
22✔
678
  if (tag < 0) {
22!
679
    code = TSDB_CODE_MND_TAG_NOT_EXIST;
×
680
    TAOS_RETURN(code);
×
681
  }
682
  TAOS_CHECK_RETURN(mndAllocStbSchemas(pOld, pNew));
22!
683
  SSchema *pTag = pNew->pTags + tag;
22✔
684

685
  if (on == 1) {
22✔
686
    if (hasIdx && tag != 0) {
14!
687
      code = TSDB_CODE_MND_TAG_INDEX_ALREADY_EXIST;
×
688
      TAOS_RETURN(code);
×
689
    } else {
690
      SSCHMEA_SET_IDX_ON(pTag);
14✔
691
    }
692
  } else {
693
    if (hasIdx == 0) {
8!
694
      code = TSDB_CODE_MND_SMA_NOT_EXIST;
×
695
    } else {
696
      SSCHMEA_SET_IDX_OFF(pTag);
8✔
697
      pTag->flags = 0;
8✔
698
    }
699
  }
700
  pNew->tagVer++;
22✔
701

702
  SSdbRaw *pCommitRaw = mndStbActionEncode(pNew);
22✔
703
  if (pCommitRaw == NULL) {
22!
704
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
705
    if (terrno != 0) code = terrno;
×
706
    TAOS_RETURN(code);
×
707
  }
708
  TAOS_CHECK_RETURN(mndTransAppendCommitlog(pTrans, pCommitRaw));
22!
709
  TAOS_CHECK_RETURN(sdbSetRawStatus(pCommitRaw, SDB_STATUS_READY));
22!
710

711
  TAOS_RETURN(code);
22✔
712
}
713
int32_t mndAddIndexImpl(SMnode *pMnode, SRpcMsg *pReq, SDbObj *pDb, SStbObj *pStb, SIdxObj *pIdx) {
14✔
714
  // impl later
715
  int32_t code = -1;
14✔
716
  SStbObj newStb = {0};
14✔
717
  STrans *pTrans = mndTransCreate(pMnode, TRN_POLICY_RETRY, TRN_CONFLICT_DB_INSIDE, pReq, "create-stb-index");
14✔
718
  if (pTrans == NULL) goto _OVER;
14!
719

720
  // mInfo("trans:%d, used to add index to stb:%s", pTrans->id, pStb->name);
721
  mndTransSetDbName(pTrans, pDb->name, pStb->name);
14✔
722
  TAOS_CHECK_GOTO(mndTransCheckConflict(pMnode, pTrans), NULL, _OVER);
14!
723

724
  mndTransSetSerial(pTrans);
14✔
725

726
  TAOS_CHECK_GOTO(mndSetCreateIdxPrepareLogs(pMnode, pTrans, pIdx), NULL, _OVER);
14!
727
  TAOS_CHECK_GOTO(mndSetCreateIdxCommitLogs(pMnode, pTrans, pIdx), NULL, _OVER);
14!
728

729
  TAOS_CHECK_GOTO(mndSetUpdateIdxStbCommitLogs(pMnode, pTrans, pStb, &newStb, pIdx->colName, 1), NULL, _OVER);
14!
730
  TAOS_CHECK_GOTO(mndSetCreateIdxRedoActions(pMnode, pTrans, pDb, &newStb, pIdx), NULL, _OVER);
14!
731

732
  TAOS_CHECK_GOTO(mndTransPrepare(pMnode, pTrans), NULL, _OVER);
14!
733

734
  code = 0;
14✔
735

736
_OVER:
14✔
737
  // mndDestoryIdxObj(pIdx);
738
  if (newStb.pTags != NULL) {
14!
739
    taosMemoryFree(newStb.pTags);
14!
740
    taosMemoryFree(newStb.pColumns);
14!
741
    taosMemoryFree(newStb.pCmpr);
14!
742
    taosMemoryFreeClear(newStb.pExtSchemas);
14!
743
  }
744
  mndTransDrop(pTrans);
14✔
745
  TAOS_RETURN(code);
14✔
746
}
747
int8_t mndCheckIndexNameByTagName(SMnode *pMnode, SIdxObj *pIdxObj) {
9✔
748
  // build index on first tag, and no index name;
749
  int8_t  exist = 0;
9✔
750
  SDbObj *pDb = NULL;
9✔
751
  if (strlen(pIdxObj->db) > 0) {
9!
752
    pDb = mndAcquireDb(pMnode, pIdxObj->db);
9✔
753
    if (pDb == NULL) return 0;
9!
754
  }
755
  SSmaAndTagIter *pIter = NULL;
9✔
756
  SIdxObj        *pIdx = NULL;
9✔
757
  SSdb           *pSdb = pMnode->pSdb;
9✔
758

759
  while (1) {
760
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
13✔
761
    if (pIter == NULL) break;
13!
762

763
    if (NULL != pDb && pIdx->dbUid != pDb->uid) {
13!
764
      sdbRelease(pSdb, pIdx);
×
765
      continue;
×
766
    }
767
    if (pIdxObj->stbUid != pIdx->stbUid) {
13!
768
      sdbRelease(pSdb, pIdx);
×
769
      continue;
×
770
    }
771
    if (strncmp(pIdxObj->colName, pIdx->colName, TSDB_COL_NAME_LEN) == 0) {
13✔
772
      sdbCancelFetch(pSdb, pIter);
9✔
773
      sdbRelease(pSdb, pIdx);
9✔
774
      exist = 1;
9✔
775
      break;
9✔
776
    }
777
    sdbRelease(pSdb, pIdx);
4✔
778
  }
779

780
  mndReleaseDb(pMnode, pDb);
9✔
781
  return exist;
9✔
782
}
783
static int32_t mndAddIndex(SMnode *pMnode, SRpcMsg *pReq, SCreateTagIndexReq *req, SDbObj *pDb, SStbObj *pStb) {
26✔
784
  int32_t code = -1;
26✔
785
  SIdxObj idxObj = {0};
26✔
786
  memcpy(idxObj.name, req->idxName, TSDB_INDEX_FNAME_LEN);
26✔
787
  memcpy(idxObj.stb, pStb->name, TSDB_TABLE_FNAME_LEN);
26✔
788
  memcpy(idxObj.db, pDb->name, TSDB_DB_FNAME_LEN);
26✔
789
  memcpy(idxObj.colName, req->colName, TSDB_COL_NAME_LEN);
26✔
790

791
  idxObj.createdTime = taosGetTimestampMs();
26✔
792
  idxObj.uid = mndGenerateUid(req->idxName, strlen(req->idxName));
26✔
793
  idxObj.stbUid = pStb->uid;
26✔
794
  idxObj.dbUid = pStb->dbUid;
26✔
795

796
  int8_t  hasIdx = 0;
26✔
797
  int32_t tag = mndFindSuperTableTagId(pStb, req->colName, &hasIdx);
26✔
798
  if (tag < 0) {
26!
799
    code = TSDB_CODE_MND_TAG_NOT_EXIST;
×
800
    TAOS_RETURN(code);
×
801
  }
802
  int8_t exist = 0;
26✔
803
  if (tag == 0 && hasIdx == 1) {
26✔
804
    exist = mndCheckIndexNameByTagName(pMnode, &idxObj);
9✔
805
    if (exist) {
9!
806
      code = TSDB_CODE_MND_TAG_INDEX_ALREADY_EXIST;
9✔
807
      TAOS_RETURN(code);
9✔
808
    }
809
  } else if (hasIdx == 1) {
17✔
810
    code = TSDB_CODE_MND_TAG_INDEX_ALREADY_EXIST;
3✔
811
    TAOS_RETURN(code);
3✔
812
  }
813

814
  code = mndAddIndexImpl(pMnode, pReq, pDb, pStb, &idxObj);
14✔
815
  TAOS_RETURN(code);
14✔
816
}
817

818
static int32_t mndDropIdx(SMnode *pMnode, SRpcMsg *pReq, SDbObj *pDb, SIdxObj *pIdx) {
8✔
819
  int32_t  code = -1;
8✔
820
  SStbObj *pStb = NULL;
8✔
821
  STrans  *pTrans = NULL;
8✔
822

823
  SStbObj newObj = {0};
8✔
824

825
  pStb = mndAcquireStb(pMnode, pIdx->stb);
8✔
826
  if (pStb == NULL) {
8!
827
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
828
    if (terrno != 0) code = terrno;
×
829
    goto _OVER;
×
830
  }
831

832
  pTrans = mndTransCreate(pMnode, TRN_POLICY_RETRY, TRN_CONFLICT_DB, pReq, "drop-index");
8✔
833
  if (pTrans == NULL) {
8!
834
    code = TSDB_CODE_MND_RETURN_VALUE_NULL;
×
835
    if (terrno != 0) code = terrno;
×
836
    goto _OVER;
×
837
  }
838

839
  mInfo("trans:%d, used to drop idx:%s", pTrans->id, pIdx->name);
8!
840
  mndTransSetDbName(pTrans, pDb->name, pStb->name);
8✔
841
  TAOS_CHECK_GOTO(mndTransCheckConflict(pMnode, pTrans), NULL, _OVER);
8!
842

843
  mndTransSetSerial(pTrans);
8✔
844
  TAOS_CHECK_GOTO(mndSetDropIdxPrepareLogs(pMnode, pTrans, pIdx), NULL, _OVER);
8!
845
  TAOS_CHECK_GOTO(mndSetDropIdxCommitLogs(pMnode, pTrans, pIdx), NULL, _OVER);
8!
846

847
  TAOS_CHECK_GOTO(mndSetUpdateIdxStbCommitLogs(pMnode, pTrans, pStb, &newObj, pIdx->colName, 0), NULL, _OVER);
8!
848
  TAOS_CHECK_GOTO(mndSetDropIdxRedoActions(pMnode, pTrans, pDb, &newObj, pIdx), NULL, _OVER);
8!
849
  TAOS_CHECK_GOTO(mndTransPrepare(pMnode, pTrans), NULL, _OVER);
8!
850

851
  code = 0;
8✔
852

853
_OVER:
8✔
854
  taosMemoryFree(newObj.pTags);
8!
855
  taosMemoryFree(newObj.pColumns);
8!
856
  taosMemoryFree(newObj.pCmpr);
8!
857
  taosMemoryFreeClear(newObj.pExtSchemas);
8!
858

859
  mndTransDrop(pTrans);
8✔
860
  mndReleaseStb(pMnode, pStb);
8✔
861
  TAOS_RETURN(code);
8✔
862
}
863
int32_t mndProcessDropTagIdxReq(SRpcMsg *pReq) {
16✔
864
  SMnode  *pMnode = pReq->info.node;
16✔
865
  int32_t  code = -1;
16✔
866
  SDbObj  *pDb = NULL;
16✔
867
  SIdxObj *pIdx = NULL;
16✔
868

869
  SDropTagIndexReq req = {0};
16✔
870
  TAOS_CHECK_GOTO(tDeserializeSDropTagIdxReq(pReq->pCont, pReq->contLen, &req), NULL, _OVER);
16!
871
  mInfo("idx:%s, start to drop", req.name);
16!
872
  SSIdx idx = {0};
16✔
873
  if ((code = mndAcquireGlobalIdx(pMnode, req.name, SDB_IDX, &idx)) == 0) {
16!
874
    pIdx = idx.pIdx;
16✔
875
  } else {
876
    goto _OVER;
×
877
  }
878
  if (pIdx == NULL) {
16✔
879
    if (req.igNotExists) {
8!
880
      mInfo("idx:%s, not exist, ignore not exist is set", req.name);
×
881
      code = 0;
×
882
      goto _OVER;
×
883
    } else {
884
      code = TSDB_CODE_MND_TAG_INDEX_NOT_EXIST;
8✔
885
      goto _OVER;
8✔
886
    }
887
  }
888

889
  pDb = mndAcquireDbByIdx(pMnode, req.name);
8✔
890
  if (pDb == NULL) {
8!
891
    terrno = TSDB_CODE_MND_DB_NOT_SELECTED;
×
892
    if (terrno != 0) code = terrno;
×
893
    goto _OVER;
×
894
  }
895

896
  if(pDb->cfg.isMount) {
8!
897
    code = TSDB_CODE_MND_MOUNT_OBJ_NOT_SUPPORT;
×
898
    goto _OVER;
×
899
  }
900

901
  TAOS_CHECK_GOTO(mndCheckDbPrivilege(pMnode, pReq->info.conn.user, MND_OPER_WRITE_DB, pDb), NULL, _OVER);
8!
902

903
  code = mndDropIdx(pMnode, pReq, pDb, pIdx);
8✔
904
  if (code == 0) code = TSDB_CODE_ACTION_IN_PROGRESS;
8!
905

906
_OVER:
×
907
  if (code != 0 && code != TSDB_CODE_ACTION_IN_PROGRESS) {
16!
908
    mError("idx:%s, failed to drop since %s", req.name, tstrerror(code));
8!
909
  }
910
  mndReleaseIdx(pMnode, pIdx);
16✔
911
  mndReleaseDb(pMnode, pDb);
16✔
912
  TAOS_RETURN(code);
16✔
913
}
914
static int32_t mndProcessGetIdxReq(SRpcMsg *pReq) {
×
915
  // do nothing
916
  return 0;
×
917
}
918

919
int32_t mndDropIdxsByStb(SMnode *pMnode, STrans *pTrans, SDbObj *pDb, SStbObj *pStb) {
834✔
920
  int32_t code = 0;
834✔
921
  SSdb   *pSdb = pMnode->pSdb;
834✔
922
  void   *pIter = NULL;
834✔
923

924
  while (1) {
6,289✔
925
    SIdxObj *pIdx = NULL;
7,123✔
926
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
7,123✔
927
    if (pIter == NULL) break;
7,123✔
928

929
    if (pIdx->stbUid == pStb->uid) {
6,289✔
930
      if ((code = mndSetDropIdxCommitLogs(pMnode, pTrans, pIdx)) != 0) {
743!
931
        sdbCancelFetch(pSdb, pIter);
×
932
        sdbRelease(pSdb, pIdx);
×
933
        TAOS_RETURN(code);
×
934
      }
935
    }
936

937
    sdbRelease(pSdb, pIdx);
6,289✔
938
  }
939

940
  TAOS_RETURN(code);
834✔
941
}
942

943
int32_t mndGetIdxsByTagName(SMnode *pMnode, SStbObj *pStb, char *tagName, SIdxObj *idx) {
1,096✔
944
  SSdb *pSdb = pMnode->pSdb;
1,096✔
945
  void *pIter = NULL;
1,096✔
946

947
  while (1) {
2,457✔
948
    SIdxObj *pIdx = NULL;
3,553✔
949
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
3,553✔
950
    if (pIter == NULL) break;
3,553✔
951

952
    if (pIdx->stbUid == pStb->uid && taosStrcasecmp(pIdx->colName, tagName) == 0) {
2,526✔
953
      memcpy((char *)idx, (char *)pIdx, sizeof(SIdxObj));
69✔
954
      sdbRelease(pSdb, pIdx);
69✔
955
      sdbCancelFetch(pSdb, pIter);
69✔
956
      return 0;
69✔
957
    }
958

959
    sdbRelease(pSdb, pIdx);
2,457✔
960
  }
961

962
  return -1;
1,027✔
963
}
964
int32_t mndDropIdxsByDb(SMnode *pMnode, STrans *pTrans, SDbObj *pDb) {
2,078✔
965
  int32_t code = 0;
2,078✔
966
  SSdb   *pSdb = pMnode->pSdb;
2,078✔
967
  void   *pIter = NULL;
2,078✔
968

969
  while (1) {
4,179✔
970
    SIdxObj *pIdx = NULL;
6,257✔
971
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
6,257✔
972
    if (pIter == NULL) break;
6,257✔
973

974
    if (pIdx->dbUid == pDb->uid) {
4,179✔
975
      if ((code = mndSetDropIdxCommitLogs(pMnode, pTrans, pIdx)) != 0) {
2,302!
976
        sdbRelease(pSdb, pIdx);
×
977
        sdbCancelFetch(pSdb, pIter);
×
978
        TAOS_RETURN(code);
×
979
      }
980
    }
981

982
    sdbRelease(pSdb, pIdx);
4,179✔
983
  }
984

985
  TAOS_RETURN(code);
2,078✔
986
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc