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

taosdata / TDengine / #4822

27 Oct 2025 05:42AM UTC coverage: 59.732% (+1.0%) from 58.728%
#4822

push

travis-ci

web-flow
Merge pull request #33377 from taosdata/fix/main/rename-udf-path

fix: update UDF example links to correct file paths

121214 of 258518 branches covered (46.89%)

Branch coverage included in aggregate %.

193636 of 268583 relevant lines covered (72.1%)

4002399.5 hits per line

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

62.78
/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 "mndShow.h"
25
#include "mndStb.h"
26
#include "mndStream.h"
27
#include "mndTrans.h"
28
#include "mndUser.h"
29
#include "mndVgroup.h"
30
#include "parser.h"
31
#include "tname.h"
32

33
#define TSDB_IDX_VER_NUMBER   1
34
#define TSDB_IDX_RESERVE_SIZE 64
35

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

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

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

62
  mndSetMsgHandle(pMnode, TDMT_MND_CREATE_INDEX, mndProcessCreateIdxReq);
1,306✔
63
  // mndSetMsgHandle(pMnode, TDMT_MND_DROP_INDEX, mndProcessDropIdxReq);
64

65
  mndSetMsgHandle(pMnode, TDMT_VND_CREATE_INDEX_RSP, mndTransProcessRsp);
1,306✔
66
  mndSetMsgHandle(pMnode, TDMT_VND_DROP_INDEX_RSP, mndTransProcessRsp);
1,306✔
67

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

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

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

91
  return TSDB_CODE_MND_TAG_NOT_EXIST;
×
92
}
93

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

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

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

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

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

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

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

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

156
  pHead->contLen = htonl(len);
10✔
157
  pHead->vgId = htonl(pVgroup->vgId);
10✔
158

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

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

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

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

209
  TAOS_RETURN(code);
5✔
210
}
211

212
void mndCleanupIdx(SMnode *pMnode) {
1,306✔
213
  // do nothing
214
  return;
1,306✔
215
}
216

217
static SSdbRaw *mndIdxActionEncode(SIdxObj *pIdx) {
20,587✔
218
  int32_t code = 0;
20,587✔
219
  int32_t lino = 0;
20,587✔
220
  terrno = TSDB_CODE_OUT_OF_MEMORY;
20,587✔
221

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

226
  SSdbRaw *pRaw = sdbAllocRaw(SDB_IDX, TSDB_IDX_VER_NUMBER, size);
20,587✔
227
  if (pRaw == NULL) goto _OVER;
20,587!
228

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

240
  SDB_SET_RESERVE(pRaw, dataPos, TSDB_IDX_RESERVE_SIZE, _OVER)
20,587!
241
  SDB_SET_DATALEN(pRaw, dataPos, _OVER)
20,587!
242

243
  terrno = 0;
20,587✔
244

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

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

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

263
  int8_t sver = 0;
11,518✔
264
  if (sdbGetRawSoftVer(pRaw, &sver) != 0) goto _OVER;
11,518!
265

266
  if (sver != TSDB_IDX_VER_NUMBER) {
11,518!
267
    terrno = TSDB_CODE_SDB_INVALID_DATA_VER;
×
268
    goto _OVER;
×
269
  }
270

271
  pRow = sdbAllocRow(sizeof(SIdxObj));
11,518✔
272
  if (pRow == NULL) goto _OVER;
11,518!
273

274
  pIdx = sdbGetRowObj(pRow);
11,518✔
275
  if (pIdx == NULL) goto _OVER;
11,518!
276

277
  int32_t dataPos = 0;
11,518✔
278

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

289
  SDB_GET_RESERVE(pRaw, dataPos, TSDB_IDX_RESERVE_SIZE, _OVER)
11,518!
290

291
  terrno = 0;
11,518✔
292

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

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

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

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

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

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

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

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

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

343
  return mndAcquireDb(pMnode, db);
5✔
344
}
345

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

357
  TAOS_RETURN(code);
10✔
358
}
359

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

371
  TAOS_RETURN(code);
5,047✔
372
}
373

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

388
  TAOS_RETURN(code);
27✔
389
}
390

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

405
  TAOS_RETURN(code);
27✔
406
}
407

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

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

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

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

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

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

469
  SDbObj            *pDb = NULL;
26✔
470
  SCreateTagIndexReq createReq = {0};
26✔
471

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

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

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

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

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

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

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

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

523
  mndReleaseStb(pMnode, pStb);
17✔
524
  mndReleaseIdx(pMnode, pIdx);
17✔
525
  mndReleaseDb(pMnode, pDb);
17✔
526

527
  TAOS_RETURN(code);
17✔
528
}
529

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

541
  TAOS_RETURN(code);
14✔
542
}
543

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

555
  TAOS_RETURN(code);
2,108✔
556
}
557

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

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

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

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

587
    cols = 0;
63✔
588

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

596
    STR_TO_VARSTR(n1, (char *)tNameGetTableName(&idxName));
63✔
597

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

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

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

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

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

618
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
63✔
619

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

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

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

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

632
    pColInfo = taosArrayGet(pBlock->pDataBlock, cols++);
63✔
633

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

638
    numOfRows++;
63✔
639
    sdbRelease(pSdb, pIdx);
63✔
640
  }
641

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

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

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

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

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

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

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

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

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

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

723
  mndTransSetSerial(pTrans);
10✔
724

725
  TAOS_CHECK_GOTO(mndSetCreateIdxPrepareLogs(pMnode, pTrans, pIdx), NULL, _OVER);
10!
726
  TAOS_CHECK_GOTO(mndSetCreateIdxCommitLogs(pMnode, pTrans, pIdx), NULL, _OVER);
10!
727

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

731
  TAOS_CHECK_GOTO(mndTransPrepare(pMnode, pTrans), NULL, _OVER);
10!
732

733
  code = 0;
10✔
734

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

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

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

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

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

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

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

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

822
  SStbObj newObj = {0};
5✔
823

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

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

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

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

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

850
  code = 0;
5✔
851

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

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

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

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

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

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

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

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

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

923
  while (1) {
16,343✔
924
    SIdxObj *pIdx = NULL;
17,280✔
925
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
17,280✔
926
    if (pIter == NULL) break;
17,280✔
927

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

936
    sdbRelease(pSdb, pIdx);
16,343✔
937
  }
938

939
  TAOS_RETURN(code);
937✔
940
}
941

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

946
  while (1) {
1,709✔
947
    SIdxObj *pIdx = NULL;
2,629✔
948
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
2,629✔
949
    if (pIter == NULL) break;
2,629✔
950

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

958
    sdbRelease(pSdb, pIdx);
1,709✔
959
  }
960

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

968
  while (1) {
2,706✔
969
    SIdxObj *pIdx = NULL;
4,135✔
970
    pIter = sdbFetch(pSdb, SDB_IDX, pIter, (void **)&pIdx);
4,135✔
971
    if (pIter == NULL) break;
4,135✔
972

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

981
    sdbRelease(pSdb, pIdx);
2,706✔
982
  }
983

984
  TAOS_RETURN(code);
1,429✔
985
}
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