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

taosdata / TDengine / #5019

10 Apr 2026 06:58AM UTC coverage: 72.254% (-0.002%) from 72.256%
#5019

push

travis-ci

web-flow
merge: from main to 3.0 #35103

77 of 116 new or added lines in 3 files covered. (66.38%)

2985 existing lines in 127 files now uncovered.

257415 of 356263 relevant lines covered (72.25%)

134284372.15 hits per line

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

79.18
/source/dnode/vnode/src/meta/metaTable.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
#include "meta.h"
17

18
extern SDmNotifyHandle dmNotifyHdl;
19

20
int32_t metaAddTableColumn(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
21
int32_t metaDropTableColumn(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
22
int32_t metaAlterTableColumnName(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
23
int32_t metaAlterTableColumnBytes(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
24
int32_t metaUpdateTableMultiTableTagValue(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq);
25
int32_t metaUpdateTableChildTableTagValue(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq);
26
int32_t metaUpdateTableOptions2(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq);
27
int32_t metaUpdateTableColCompress2(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq);
28
int32_t metaAlterTableColumnRef(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
29
int32_t metaRemoveTableColumnRef(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pRsp);
30
int32_t metaSaveJsonVarToIdx(SMeta *pMeta, const SMetaEntry *pCtbEntry, const SSchema *pSchema);
31

32
int32_t    metaDelJsonVarFromIdx(SMeta *pMeta, const SMetaEntry *pCtbEntry, const SSchema *pSchema);
33
static int metaUpdateChangeTime(SMeta *pMeta, tb_uid_t uid, int64_t changeTimeMs);
34
static int metaDropTableByUid(SMeta *pMeta, tb_uid_t uid, int *type, tb_uid_t *pSuid, int8_t *pSysTbl);
35
void       metaDestroyTagIdxKey(STagIdxKey *pTagIdxKey);
36
// opt ins_tables query
37
static int metaDeleteBtimeIdx(SMeta *pMeta, const SMetaEntry *pME);
38
static int metaDeleteNcolIdx(SMeta *pMeta, const SMetaEntry *pME);
39

40
int32_t updataTableColCmpr(SColCmprWrapper *pWp, SSchema *pSchema, int8_t add, uint32_t compress) {
3,345,424✔
41
  int32_t nCols = pWp->nCols;
3,345,424✔
42
  int32_t ver = pWp->version;
3,345,424✔
43
  if (add) {
3,345,424✔
44
    SColCmpr *p = taosMemoryRealloc(pWp->pColCmpr, sizeof(SColCmpr) * (nCols + 1));
3,290,003✔
45
    if (p == NULL) {
3,290,003✔
46
      return terrno;
×
47
    }
48
    pWp->pColCmpr = p;
3,290,003✔
49

50
    SColCmpr *pCol = p + nCols;
3,290,003✔
51
    pCol->id = pSchema->colId;
3,290,003✔
52
    pCol->alg = compress;
3,290,003✔
53
    pWp->nCols = nCols + 1;
3,290,003✔
54
    pWp->version = ver;
3,290,003✔
55
  } else {
56
    for (int32_t i = 0; i < nCols; i++) {
13,202,135✔
57
      SColCmpr *pOCmpr = &pWp->pColCmpr[i];
13,202,135✔
58
      if (pOCmpr->id == pSchema->colId) {
13,202,135✔
59
        int32_t left = (nCols - i - 1) * sizeof(SColCmpr);
55,421✔
60
        if (left) {
55,421✔
61
          memmove(pWp->pColCmpr + i, pWp->pColCmpr + i + 1, left);
33,987✔
62
        }
63
        nCols--;
55,421✔
64
        break;
55,421✔
65
      }
66
    }
67
    pWp->nCols = nCols;
55,421✔
68
    pWp->version = ver;
55,421✔
69
  }
70
  return 0;
3,345,424✔
71
}
72

73
int32_t addTableExtSchema(SMetaEntry *pEntry, const SSchema *pColumn, int32_t newColNum, SExtSchema *pExtSchema) {
3,347,806✔
74
  // no need to add ext schema when no column needs ext schemas
75
  if (!HAS_TYPE_MOD(pColumn) && !pEntry->pExtSchemas) return 0;
3,347,806✔
76
  if (!pEntry->pExtSchemas) {
15,074✔
77
    // add a column which needs ext schema
78
    // set all extschemas to zero for all columns alrady existed
79
    pEntry->pExtSchemas = (SExtSchema *)taosMemoryCalloc(newColNum, sizeof(SExtSchema));
2,331✔
80
  } else {
81
    // already has columns with ext schema
82
    pEntry->pExtSchemas = (SExtSchema *)taosMemoryRealloc(pEntry->pExtSchemas, sizeof(SExtSchema) * newColNum);
12,743✔
83
  }
84
  if (!pEntry->pExtSchemas) return terrno;
15,074✔
85
  pEntry->pExtSchemas[newColNum - 1] = *pExtSchema;
15,074✔
86
  return 0;
15,074✔
87
}
88

89
int32_t dropTableExtSchema(SMetaEntry *pEntry, int32_t dropColId, int32_t newColNum) {
87,006✔
90
  // no ext schema, no need to drop
91
  if (!pEntry->pExtSchemas) return 0;
87,006✔
92
  if (dropColId == newColNum) {
10,711✔
93
    // drop the last column
94
    pEntry->pExtSchemas[dropColId - 1] = (SExtSchema){0};
3,878✔
95
  } else {
96
    // drop a column in the middle
97
    memmove(pEntry->pExtSchemas + dropColId, pEntry->pExtSchemas + dropColId + 1,
6,833✔
98
            (newColNum - dropColId) * sizeof(SExtSchema));
6,833✔
99
  }
100
  for (int32_t i = 0; i < newColNum; i++) {
40,070✔
101
    if (hasExtSchema(pEntry->pExtSchemas + i)) return 0;
38,516✔
102
  }
103
  taosMemoryFreeClear(pEntry->pExtSchemas);
1,554✔
104
  return 0;
1,554✔
105
}
106

107
int32_t updataTableColRef(SColRefWrapper *pWp, const SSchema *pSchema, int8_t add, SColRef *pColRef) {
100,481✔
108
  int32_t nCols = pWp->nCols;
100,481✔
109
  if (add) {
100,481✔
110
    SColRef *p = taosMemoryRealloc(pWp->pColRef, sizeof(SColRef) * (nCols + 1));
64,301✔
111
    if (p == NULL) {
64,301✔
112
      return terrno;
×
113
    }
114
    pWp->pColRef = p;
64,301✔
115

116
    SColRef *pCol = p + nCols;
64,301✔
117
    if (NULL == pColRef) {
64,301✔
118
      pCol->hasRef = false;
6,498✔
119
      pCol->id = pSchema->colId;
6,498✔
120
    } else {
121
      pCol->hasRef = pColRef->hasRef;
57,803✔
122
      pCol->id = pSchema->colId;
57,803✔
123
      if (pCol->hasRef) {
57,803✔
124
        tstrncpy(pCol->refDbName, pColRef->refDbName, TSDB_DB_NAME_LEN);
24,469✔
125
        tstrncpy(pCol->refTableName, pColRef->refTableName, TSDB_TABLE_NAME_LEN);
24,469✔
126
        tstrncpy(pCol->refColName, pColRef->refColName, TSDB_COL_NAME_LEN);
24,469✔
127
      }
128
    }
129
    pWp->nCols = nCols + 1;
64,301✔
130
    pWp->version++;
64,301✔
131
  } else {
132
    for (int32_t i = 0; i < nCols; i++) {
38,076,289✔
133
      SColRef *pOColRef = &pWp->pColRef[i];
38,076,289✔
134
      if (pOColRef->id == pSchema->colId) {
38,076,289✔
135
        int32_t left = (nCols - i - 1) * sizeof(SColRef);
36,180✔
136
        if (left) {
36,180✔
137
          memmove(pWp->pColRef + i, pWp->pColRef + i + 1, left);
32,945✔
138
        }
139
        nCols--;
36,180✔
140
        break;
36,180✔
141
      }
142
    }
143
    pWp->nCols = nCols;
36,180✔
144
    pWp->version++;
36,180✔
145
  }
146
  return 0;
100,481✔
147
}
148

149
int metaUpdateMetaRsp(tb_uid_t uid, char *tbName, SSchemaWrapper *pSchema, int64_t ownerId, STableMetaRsp *pMetaRsp) {
11,319,912✔
150
  pMetaRsp->pSchemas = taosMemoryMalloc(pSchema->nCols * sizeof(SSchema));
11,319,912✔
151
  if (NULL == pMetaRsp->pSchemas) {
11,319,912✔
152
    return terrno;
×
153
  }
154

155
  pMetaRsp->pSchemaExt = taosMemoryCalloc(1, pSchema->nCols * sizeof(SSchemaExt));
11,319,912✔
156
  if (pMetaRsp->pSchemaExt == NULL) {
11,319,912✔
157
    taosMemoryFree(pMetaRsp->pSchemas);
×
158
    return terrno;
×
159
  }
160

161
  tstrncpy(pMetaRsp->tbName, tbName, TSDB_TABLE_NAME_LEN);
11,319,912✔
162
  pMetaRsp->numOfColumns = pSchema->nCols;
11,319,912✔
163
  pMetaRsp->tableType = TSDB_NORMAL_TABLE;
11,319,912✔
164
  pMetaRsp->sversion = pSchema->version;
11,319,912✔
165
  pMetaRsp->rversion = 1;
11,319,912✔
166
  pMetaRsp->tuid = uid;
11,319,912✔
167
  pMetaRsp->virtualStb = false; // super table will never be processed here
11,319,912✔
168
  if (ownerId != 0) pMetaRsp->ownerId = ownerId;
11,319,912✔
169

170
  memcpy(pMetaRsp->pSchemas, pSchema->pSchema, pSchema->nCols * sizeof(SSchema));
11,319,912✔
171

172
  return 0;
11,319,912✔
173
}
174

175
static int32_t metaFillRspSchemaExt(const SSchemaWrapper *pSchema, const SExtSchema *pExtSchemas, SSchemaExt *pSchemaExt) {
846,953✔
176
  if (pSchema == NULL || pSchemaExt == NULL) {
846,953✔
177
    return TSDB_CODE_SUCCESS;
×
178
  }
179

180
  for (int32_t i = 0; i < pSchema->nCols; ++i) {
235,808,364✔
181
    pSchemaExt[i].colId = pSchema->pSchema[i].colId;
234,961,411✔
182
  }
183

184
  if (pExtSchemas != NULL) {
846,953✔
185
    for (int32_t i = 0; i < pSchema->nCols; ++i) {
156,227✔
186
      pSchemaExt[i].typeMod = pExtSchemas[i].typeMod;
139,673✔
187
    }
188
  }
189

190
  return TSDB_CODE_SUCCESS;
846,953✔
191
}
192

193
int32_t metaUpdateVtbMetaRsp(SMetaEntry *pEntry, char *tbName, const SSchemaWrapper *pSchema, const SColRefWrapper *pRef,
846,953✔
194
                             const SExtSchema *pExtSchemas, int64_t ownerId, STableMetaRsp *pMetaRsp, int8_t tableType) {
195
  int32_t code = TSDB_CODE_SUCCESS;
846,953✔
196
  if (!pRef) {
846,953✔
197
    return TSDB_CODE_INVALID_PARA;
×
198
  }
199
  if (pSchema) {
846,953✔
200
    pMetaRsp->pSchemas = taosMemoryMalloc(pSchema->nCols * sizeof(SSchema));
846,953✔
201
    if (NULL == pMetaRsp->pSchemas) {
846,953✔
202
      code = terrno;
×
203
      goto _return;
×
204
    }
205

206
    pMetaRsp->pSchemaExt = taosMemoryCalloc(pSchema->nCols, sizeof(SSchemaExt));
846,953✔
207
    if (pMetaRsp->pSchemaExt == NULL) {
846,953✔
208
      code = terrno;
×
209
      goto _return;
×
210
    }
211

212
    pMetaRsp->numOfColumns = pSchema->nCols;
846,953✔
213
    pMetaRsp->sversion = pSchema->version;
846,953✔
214
    memcpy(pMetaRsp->pSchemas, pSchema->pSchema, pSchema->nCols * sizeof(SSchema));
846,953✔
215

216
    code = metaFillRspSchemaExt(pSchema, pExtSchemas, pMetaRsp->pSchemaExt);
846,953✔
217
    if (code != TSDB_CODE_SUCCESS) {
846,953✔
218
      goto _return;
×
219
    }
220
  }
221

222
  if (pRef->nCols > 0) {
846,953✔
223
    pMetaRsp->pColRefs = taosMemoryMalloc(pRef->nCols * sizeof(SColRef));
846,953✔
224
    if (NULL == pMetaRsp->pColRefs) {
846,953✔
225
      code = terrno;
×
226
      goto _return;
×
227
    }
228

229
    memcpy(pMetaRsp->pColRefs, pRef->pColRef, pRef->nCols * sizeof(SColRef));
846,953✔
230
  } else {
231
    pMetaRsp->pColRefs = NULL;
×
232
  }
233

234
  tstrncpy(pMetaRsp->tbName, tbName, TSDB_TABLE_NAME_LEN);
846,953✔
235
  if (tableType == TSDB_VIRTUAL_NORMAL_TABLE) {
846,953✔
236
    pMetaRsp->tuid = pEntry->uid;
428,232✔
237
  } else if (tableType == TSDB_VIRTUAL_CHILD_TABLE) {
418,721✔
238
    pMetaRsp->tuid = pEntry->uid;
418,721✔
239
    pMetaRsp->suid = pEntry->ctbEntry.suid;
418,721✔
240
  }
241

242
  pMetaRsp->tableType = tableType;
846,953✔
243
  pMetaRsp->virtualStb = false; // super table will never be processed here
846,953✔
244
  pMetaRsp->numOfColRefs = pRef->nCols;
846,953✔
245
  pMetaRsp->rversion = pRef->version;
846,953✔
246
  if (ownerId != 0) pMetaRsp->ownerId = ownerId;
846,953✔
247

248
  // Populate tag references
249
  if (pRef->nTagRefs > 0 && pRef->pTagRef) {
846,953✔
250
    pMetaRsp->pTagRefs = taosMemoryMalloc(pRef->nTagRefs * sizeof(SColRef));
×
251
    if (NULL == pMetaRsp->pTagRefs) {
×
252
      code = terrno;
×
253
      goto _return;
×
254
    }
255
    memcpy(pMetaRsp->pTagRefs, pRef->pTagRef, pRef->nTagRefs * sizeof(SColRef));
×
256
    pMetaRsp->numOfTagRefs = pRef->nTagRefs;
×
257
  } else {
258
    pMetaRsp->pTagRefs = NULL;
846,953✔
259
    pMetaRsp->numOfTagRefs = 0;
846,953✔
260
  }
261

262
  return code;
846,953✔
263
_return:
×
264
  taosMemoryFreeClear(pMetaRsp->pSchemaExt);
×
265
  taosMemoryFreeClear(pMetaRsp->pSchemas);
×
266
  taosMemoryFreeClear(pMetaRsp->pColRefs);
×
267
  taosMemoryFreeClear(pMetaRsp->pTagRefs);
×
268
  return code;
×
269
}
270

271
int metaSaveJsonVarToIdx(SMeta *pMeta, const SMetaEntry *pCtbEntry, const SSchema *pSchema) {
263,718✔
272
  int32_t code = 0;
263,718✔
273

274
#ifdef USE_INVERTED_INDEX
275
  if (pMeta->pTagIvtIdx == NULL || pCtbEntry == NULL) {
263,718✔
276
    return TSDB_CODE_INVALID_PARA;
×
277
  }
278
  void       *data = pCtbEntry->ctbEntry.pTags;
263,718✔
279
  const char *tagName = pSchema->name;
263,718✔
280

281
  tb_uid_t    suid = pCtbEntry->ctbEntry.suid;
263,718✔
282
  tb_uid_t    tuid = pCtbEntry->uid;
263,718✔
283
  const void *pTagData = pCtbEntry->ctbEntry.pTags;
263,718✔
284
  int32_t     nTagData = 0;
263,718✔
285

286
  SArray *pTagVals = NULL;
263,718✔
287
  code = tTagToValArray((const STag *)data, &pTagVals);
263,718✔
288
  if (code) {
263,718✔
289
    return code;
×
290
  }
291

292
  SIndexMultiTerm *terms = indexMultiTermCreate();
263,718✔
293
  if (terms == NULL) {
263,718✔
294
    return terrno;
×
295
  }
296

297
  int16_t nCols = taosArrayGetSize(pTagVals);
263,718✔
298
  for (int i = 0; i < nCols; i++) {
642,364✔
299
    STagVal *pTagVal = (STagVal *)taosArrayGet(pTagVals, i);
378,646✔
300
    char     type = pTagVal->type;
378,646✔
301

302
    char   *key = pTagVal->pKey;
378,646✔
303
    int32_t nKey = strlen(key);
378,646✔
304

305
    SIndexTerm *term = NULL;
378,646✔
306
    if (type == TSDB_DATA_TYPE_NULL) {
378,646✔
307
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
2,886✔
308
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
375,760✔
309
      if (pTagVal->nData > 0) {
358,438✔
310
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
356,514✔
311
        if (val == NULL) {
356,514✔
312
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
313
        }
314
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
356,514✔
315
        if (len < 0) {
356,514✔
316
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
317
        }
318
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
356,514✔
319
        type = TSDB_DATA_TYPE_VARCHAR;
356,514✔
320
        term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, val, len);
356,514✔
321
        taosMemoryFree(val);
356,514✔
322
      } else if (pTagVal->nData == 0) {
1,924✔
323
        term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, pTagVal->pData, 0);
1,924✔
324
      }
325
    } else if (type == TSDB_DATA_TYPE_DOUBLE) {
17,322✔
326
      double val = *(double *)(&pTagVal->i64);
13,474✔
327
      int    len = sizeof(val);
13,474✔
328
      term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, (const char *)&val, len);
13,474✔
329
    } else if (type == TSDB_DATA_TYPE_BOOL) {
3,848✔
330
      int val = *(int *)(&pTagVal->i64);
3,848✔
331
      int len = sizeof(val);
3,848✔
332
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
3,848✔
333
    }
334

335
    if (term != NULL) {
378,646✔
336
      int32_t ret = indexMultiTermAdd(terms, term);
378,646✔
337
      if (ret < 0) {
378,646✔
338
        metaError("vgId:%d, failed to add term to multi term, uid: %" PRId64 ", key: %s, type: %d, ret: %d",
×
339
                  TD_VID(pMeta->pVnode), tuid, key, type, ret);
340
      }
341
    } else {
342
      code = terrno;
×
343
      goto _exception;
×
344
    }
345
  }
346
  code = indexJsonPut(pMeta->pTagIvtIdx, terms, tuid);
263,718✔
347
  indexMultiTermDestroy(terms);
263,718✔
348

349
  taosArrayDestroy(pTagVals);
263,718✔
350
  return code;
263,718✔
351
_exception:
×
352
  indexMultiTermDestroy(terms);
×
353
  taosArrayDestroy(pTagVals);
×
354
#endif
355
  return code;
×
356
}
357
int metaDelJsonVarFromIdx(SMeta *pMeta, const SMetaEntry *pCtbEntry, const SSchema *pSchema) {
117,255✔
358
int32_t code = 0;
117,255✔
359
#ifdef USE_INVERTED_INDEX
360
  if (pMeta->pTagIvtIdx == NULL || pCtbEntry == NULL) {
117,255✔
361
    return TSDB_CODE_INVALID_PARA;
×
362
  }
363
  void       *data = pCtbEntry->ctbEntry.pTags;
117,255✔
364
  const char *tagName = pSchema->name;
117,255✔
365

366
  tb_uid_t    suid = pCtbEntry->ctbEntry.suid;
117,255✔
367
  tb_uid_t    tuid = pCtbEntry->uid;
117,255✔
368
  const void *pTagData = pCtbEntry->ctbEntry.pTags;
117,255✔
369
  int32_t     nTagData = 0;
117,255✔
370

371
  SArray *pTagVals = NULL;
117,255✔
372
  code = tTagToValArray((const STag *)data, &pTagVals);
117,255✔
373
  if (code) {
117,255✔
374
    return code;
×
375
  }
376

377
  SIndexMultiTerm *terms = indexMultiTermCreate();
117,255✔
378
  if (terms == NULL) {
117,255✔
379
    return terrno;
×
380
  }
381

382
  int16_t nCols = taosArrayGetSize(pTagVals);
117,255✔
383
  for (int i = 0; i < nCols; i++) {
336,190✔
384
    STagVal *pTagVal = (STagVal *)taosArrayGet(pTagVals, i);
218,935✔
385
    char     type = pTagVal->type;
218,935✔
386

387
    char   *key = pTagVal->pKey;
218,935✔
388
    int32_t nKey = strlen(key);
218,935✔
389

390
    SIndexTerm *term = NULL;
218,935✔
391
    if (type == TSDB_DATA_TYPE_NULL) {
218,935✔
392
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
×
393
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
218,935✔
394
      if (pTagVal->nData > 0) {
216,530✔
395
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
216,530✔
396
        if (val == NULL) {
216,530✔
397
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
398
        }
399
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
216,530✔
400
        if (len < 0) {
216,530✔
401
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
402
        }
403
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
216,530✔
404
        type = TSDB_DATA_TYPE_VARCHAR;
216,530✔
405
        term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, val, len);
216,530✔
406
        taosMemoryFree(val);
216,530✔
407
      } else if (pTagVal->nData == 0) {
×
408
        term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, pTagVal->pData, 0);
×
409
      }
410
    } else if (type == TSDB_DATA_TYPE_DOUBLE) {
2,405✔
411
      double val = *(double *)(&pTagVal->i64);
1,443✔
412
      int    len = sizeof(val);
1,443✔
413
      term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, (const char *)&val, len);
1,443✔
414
    } else if (type == TSDB_DATA_TYPE_BOOL) {
962✔
415
      int val = *(int *)(&pTagVal->i64);
962✔
416
      int len = sizeof(val);
962✔
417
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
962✔
418
    }
419
    if (term != NULL) {
218,935✔
420
      int32_t ret = indexMultiTermAdd(terms, term);
218,935✔
421
      if (ret < 0) {
218,935✔
422
        metaError("vgId:%d, failed to add term to multi term, uid: %" PRId64 ", key: %s, type: %d, ret: %d",
×
423
                  TD_VID(pMeta->pVnode), tuid, key, type, ret);
424
      }
425
    } else {
426
      code = terrno;
×
427
      goto _exception;
×
428
    }
429
  }
430
  code = indexJsonPut(pMeta->pTagIvtIdx, terms, tuid);
117,255✔
431
  indexMultiTermDestroy(terms);
117,255✔
432
  taosArrayDestroy(pTagVals);
117,255✔
433
  return code;
117,255✔
434
_exception:
×
435
  indexMultiTermDestroy(terms);
×
436
  taosArrayDestroy(pTagVals);
×
437
#endif
438
  return code;
×
439
}
440

441
static int32_t metaDropTables(SMeta *pMeta, SArray *tbUids) {
19,725✔
442
  int32_t code = 0;
19,725✔
443
  if (taosArrayGetSize(tbUids) == 0) return TSDB_CODE_SUCCESS;
19,725✔
444

445
  int64_t    nCtbDropped = 0;
19,725✔
446
  SSHashObj *suidHash = tSimpleHashInit(16, taosGetDefaultHashFunction(TSDB_DATA_TYPE_BIGINT));
19,725✔
447
  if (suidHash == NULL) {
19,725✔
448
    return terrno;
×
449
  }
450

451
  metaWLock(pMeta);
19,725✔
452
  for (int i = 0; i < taosArrayGetSize(tbUids); ++i) {
102,415✔
453
    tb_uid_t uid = *(tb_uid_t *)taosArrayGet(tbUids, i);
82,690✔
454
    tb_uid_t suid = 0;
82,690✔
455
    int8_t   sysTbl = 0;
82,690✔
456
    int      type;
82,690✔
457
    code = metaDropTableByUid(pMeta, uid, &type, &suid, &sysTbl);
82,690✔
458
    if (code) return code;
82,690✔
459
    if (!sysTbl && type == TSDB_CHILD_TABLE && suid != 0 && suidHash) {
82,690✔
460
      int64_t *pVal = tSimpleHashGet(suidHash, &suid, sizeof(tb_uid_t));
77,338✔
461
      if (pVal) {
77,338✔
462
        nCtbDropped = *pVal + 1;
60,089✔
463
      } else {
464
        nCtbDropped = 1;
17,249✔
465
      }
466
      code = tSimpleHashPut(suidHash, &suid, sizeof(tb_uid_t), &nCtbDropped, sizeof(int64_t));
77,338✔
467
      if (code) return code;
77,338✔
468
    }
469
    /*
470
    if (!TSDB_CACHE_NO(pMeta->pVnode->config)) {
471
      tsdbCacheDropTable(pMeta->pVnode->pTsdb, uid, suid, NULL);
472
    }
473
    */
474
    metaDebug("batch drop table:%" PRId64, uid);
82,690✔
475
  }
476
  metaULock(pMeta);
19,725✔
477

478
  // update timeseries
479
  void   *pCtbDropped = NULL;
19,725✔
480
  int32_t iter = 0;
19,725✔
481
  while ((pCtbDropped = tSimpleHashIterate(suidHash, pCtbDropped, &iter))) {
36,974✔
482
    tb_uid_t    *pSuid = tSimpleHashGetKey(pCtbDropped, NULL);
17,249✔
483
    int32_t      nCols = 0;
17,249✔
484
    int8_t       flags = 0;
17,249✔
485
    SVnodeStats *pStats = &pMeta->pVnode->config.vndStats;
17,249✔
486
    if (metaGetStbStats(pMeta->pVnode, *pSuid, NULL, &nCols, &flags) == 0) {
17,249✔
487
      if (!TABLE_IS_VIRTUAL(flags)) {
17,249✔
488
        pStats->numOfTimeSeries -= *(int64_t *)pCtbDropped * (nCols - 1);
17,249✔
489
      }
490
    }
491
  }
492
  tSimpleHashCleanup(suidHash);
19,725✔
493

494
  pMeta->changed = true;
19,725✔
495
  return 0;
19,725✔
496
}
497

498
static int32_t metaFilterTableByHash(SMeta *pMeta, SArray *uidList) {
25,918✔
499
  int32_t code = 0;
25,918✔
500
  // 1, tranverse table's
501
  // 2, validate table name using vnodeValidateTableHash
502
  // 3, push invalidated table's uid into uidList
503

504
  TBC *pCur;
25,918✔
505
  code = tdbTbcOpen(pMeta->pTbDb, &pCur, NULL);
25,918✔
506
  if (code < 0) {
25,918✔
507
    return code;
×
508
  }
509

510
  code = tdbTbcMoveToFirst(pCur);
25,918✔
511
  if (code) {
25,918✔
512
    tdbTbcClose(pCur);
×
513
    return code;
×
514
  }
515

516
  void *pData = NULL, *pKey = NULL;
25,918✔
517
  int   nData = 0, nKey = 0;
25,918✔
518

519
  while (1) {
184,969✔
520
    int32_t ret = tdbTbcNext(pCur, &pKey, &nKey, &pData, &nData);
210,887✔
521
    if (ret < 0) {
210,887✔
522
      break;
25,918✔
523
    }
524

525
    SMetaEntry me = {0};
184,969✔
526
    SDecoder   dc = {0};
184,969✔
527
    tDecoderInit(&dc, pData, nData);
184,969✔
528
    code = metaDecodeEntry(&dc, &me);
184,969✔
529
    if (code < 0) {
184,969✔
530
      tDecoderClear(&dc);
×
531
      return code;
×
532
    }
533

534
    if (me.type != TSDB_SUPER_TABLE) {
184,969✔
535
      char tbFName[TSDB_TABLE_FNAME_LEN + 1];
165,372✔
536
      snprintf(tbFName, sizeof(tbFName), "%s.%s", pMeta->pVnode->config.dbname, me.name);
165,372✔
537
      tbFName[TSDB_TABLE_FNAME_LEN] = '\0';
165,372✔
538
      if (pMeta->pVnode->mounted) tTrimMountPrefix(tbFName);
165,372✔
539
      ret = vnodeValidateTableHash(pMeta->pVnode, tbFName);
165,372✔
540
      if (ret < 0 && terrno == TSDB_CODE_VND_HASH_MISMATCH) {
165,372✔
541
        if (taosArrayPush(uidList, &me.uid) == NULL) {
82,690✔
542
          code = terrno;
×
543
          break;
×
544
        }
545
      }
546
    }
547
    tDecoderClear(&dc);
184,969✔
548
  }
549
  tdbFree(pData);
25,918✔
550
  tdbFree(pKey);
25,918✔
551
  tdbTbcClose(pCur);
25,918✔
552

553
  return 0;
25,918✔
554
}
555

556
int32_t metaTrimTables(SMeta *pMeta, int64_t version) {
25,918✔
557
  int32_t code = 0;
25,918✔
558

559
  SArray *tbUids = taosArrayInit(8, sizeof(int64_t));
25,918✔
560
  if (tbUids == NULL) {
25,918✔
561
    return terrno;
×
562
  }
563

564
  code = metaFilterTableByHash(pMeta, tbUids);
25,918✔
565
  if (code != 0) {
25,918✔
566
    goto end;
×
567
  }
568
  if (TARRAY_SIZE(tbUids) == 0) {
25,918✔
569
    goto end;
6,193✔
570
  }
571

572
  metaInfo("vgId:%d, trim %ld tables", TD_VID(pMeta->pVnode), taosArrayGetSize(tbUids));
19,725✔
573
  code = metaDropTables(pMeta, tbUids);
19,725✔
574
  if (code) goto end;
19,725✔
575

576
end:
19,725✔
577
  taosArrayDestroy(tbUids);
25,918✔
578

579
  return code;
25,918✔
580
}
581

582
int metaTtlFindExpired(SMeta *pMeta, int64_t timePointMs, SArray *tbUids, int32_t ttlDropMaxCount) {
10,729,583✔
583
  metaRLock(pMeta);
10,729,583✔
584

585
  int ret = ttlMgrFindExpired(pMeta->pTtlMgr, timePointMs, tbUids, ttlDropMaxCount);
10,748,111✔
586

587
  metaULock(pMeta);
10,711,785✔
588

589
  if (ret != 0) {
10,725,512✔
590
    metaError("ttl failed to find expired table, ret:%d", ret);
×
591
  }
592

593
  return ret;
10,724,945✔
594
}
595

596
static int metaBuildBtimeIdxKey(SBtimeIdxKey *btimeKey, const SMetaEntry *pME) {
82,690✔
597
  int64_t btime;
598
  if (pME->type == TSDB_CHILD_TABLE) {
82,690✔
599
    btime = pME->ctbEntry.btime;
77,338✔
600
  } else if (pME->type == TSDB_NORMAL_TABLE) {
5,352✔
601
    btime = pME->ntbEntry.btime;
5,352✔
602
  } else {
603
    return TSDB_CODE_FAILED;
×
604
  }
605

606
  btimeKey->btime = btime;
82,690✔
607
  btimeKey->uid = pME->uid;
82,690✔
608
  return 0;
82,690✔
609
}
610

611
static int metaBuildNColIdxKey(SNcolIdxKey *ncolKey, const SMetaEntry *pME) {
5,352✔
612
  if (pME->type == TSDB_NORMAL_TABLE) {
5,352✔
613
    ncolKey->ncol = pME->ntbEntry.schemaRow.nCols;
5,352✔
614
    ncolKey->uid = pME->uid;
5,352✔
615
  } else {
616
    return TSDB_CODE_FAILED;
×
617
  }
618
  return 0;
5,352✔
619
}
620

621
static void metaDeleteTtl(SMeta *pMeta, const SMetaEntry *pME) {
82,690✔
622
  if (pME->type != TSDB_CHILD_TABLE && pME->type != TSDB_NORMAL_TABLE) return;
82,690✔
623

624
  STtlDelTtlCtx ctx = {.uid = pME->uid, .pTxn = pMeta->txn};
82,690✔
625
  if (pME->type == TSDB_CHILD_TABLE) {
82,690✔
626
    ctx.ttlDays = pME->ctbEntry.ttlDays;
77,338✔
627
  } else {
628
    ctx.ttlDays = pME->ntbEntry.ttlDays;
5,352✔
629
  }
630

631
  int32_t ret = ttlMgrDeleteTtl(pMeta->pTtlMgr, &ctx);
82,690✔
632
  if (ret < 0) {
82,690✔
633
    metaError("vgId:%d, failed to delete ttl for table:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), pME->name,
×
634
              pME->uid, tstrerror(ret));
635
  }
636
  return;
82,690✔
637
}
638

639
static int metaDropTableByUid(SMeta *pMeta, tb_uid_t uid, int *type, tb_uid_t *pSuid, int8_t *pSysTbl) {
82,690✔
640
  void      *pData = NULL;
82,690✔
641
  int        nData = 0;
82,690✔
642
  int        rc = 0;
82,690✔
643
  SMetaEntry e = {0};
82,690✔
644
  SDecoder   dc = {0};
82,690✔
645
  int32_t    ret = 0;
82,690✔
646

647
  rc = tdbTbGet(pMeta->pUidIdx, &uid, sizeof(uid), &pData, &nData);
82,690✔
648
  if (rc < 0) {
82,690✔
649
    return rc;
×
650
  }
651
  int64_t version = ((SUidIdxVal *)pData)[0].version;
82,690✔
652

653
  rc = tdbTbGet(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), &pData, &nData);
82,690✔
654
  if (rc < 0) {
82,690✔
655
    tdbFree(pData);
×
656
    return rc;
×
657
  }
658

659
  tDecoderInit(&dc, pData, nData);
82,690✔
660
  rc = metaDecodeEntry(&dc, &e);
82,690✔
661
  if (rc < 0) {
82,690✔
662
    tDecoderClear(&dc);
×
663
    return rc;
×
664
  }
665

666
  if (type) *type = e.type;
82,690✔
667

668
  if (e.type == TSDB_CHILD_TABLE) {
82,690✔
669
    if (pSuid) *pSuid = e.ctbEntry.suid;
77,338✔
670
    void *tData = NULL;
77,338✔
671
    int   tLen = 0;
77,338✔
672

673
    if (tdbTbGet(pMeta->pUidIdx, &e.ctbEntry.suid, sizeof(tb_uid_t), &tData, &tLen) == 0) {
77,338✔
674
      STbDbKey tbDbKey = {.uid = e.ctbEntry.suid, .version = ((SUidIdxVal *)tData)[0].version};
77,338✔
675
      if (tdbTbGet(pMeta->pTbDb, &tbDbKey, sizeof(tbDbKey), &tData, &tLen) == 0) {
77,338✔
676
        SDecoder   tdc = {0};
77,338✔
677
        SMetaEntry stbEntry = {0};
77,338✔
678

679
        tDecoderInit(&tdc, tData, tLen);
77,338✔
680
        ret = metaDecodeEntry(&tdc, &stbEntry);
77,338✔
681
        if (ret < 0) {
77,338✔
682
          tDecoderClear(&tdc);
×
683
          metaError("vgId:%d, failed to decode child table:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
×
684
                    e.ctbEntry.suid, tstrerror(ret));
685
          return ret;
×
686
        }
687

688
        if (pSysTbl) *pSysTbl = metaTbInFilterCache(pMeta, stbEntry.name, 1) ? 1 : 0;
77,338✔
689
        
690
        ret = metaStableTagFilterCacheUpdateUid(
77,338✔
691
          pMeta, &e, &stbEntry, STABLE_TAG_FILTER_CACHE_DROP_TABLE);
692
        if (ret < 0) {
77,338✔
693
          metaError("vgId:%d, failed to update stable tag filter cache:%s "
×
694
            "uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
695
            e.ctbEntry.suid, tstrerror(ret));
696
        }
697

698
        SSchema        *pTagColumn = NULL;
77,338✔
699
        SSchemaWrapper *pTagSchema = &stbEntry.stbEntry.schemaTag;
77,338✔
700
        if (pTagSchema->nCols == 1 && pTagSchema->pSchema[0].type == TSDB_DATA_TYPE_JSON) {
77,338✔
701
          pTagColumn = &stbEntry.stbEntry.schemaTag.pSchema[0];
×
702
          ret = metaDelJsonVarFromIdx(pMeta, &e, pTagColumn);
×
703
          if (ret < 0) {
×
704
            metaError("vgId:%d, failed to delete json var from idx:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode),
×
705
                      e.name, e.uid, tstrerror(ret));
706
          }
707
        } else {
708
          for (int i = 0; i < pTagSchema->nCols; i++) {
397,512✔
709
            pTagColumn = &stbEntry.stbEntry.schemaTag.pSchema[i];
320,174✔
710
            if (!IS_IDX_ON(pTagColumn)) continue;
320,174✔
711
            STagIdxKey *pTagIdxKey = NULL;
77,338✔
712
            int32_t     nTagIdxKey;
77,338✔
713

714
            const void *pTagData = NULL;
77,338✔
715
            int32_t     nTagData = 0;
77,338✔
716

717
            STagVal tagVal = {.cid = pTagColumn->colId};
77,338✔
718
            if (tTagGet((const STag *)e.ctbEntry.pTags, &tagVal)) {
77,338✔
719
              if (IS_VAR_DATA_TYPE(pTagColumn->type)) {
77,338✔
720
                pTagData = tagVal.pData;
×
721
                nTagData = (int32_t)tagVal.nData;
×
722
              } else {
723
                pTagData = &(tagVal.i64);
77,338✔
724
                nTagData = tDataTypes[pTagColumn->type].bytes;
77,338✔
725
              }
726
            } else {
727
              if (!IS_VAR_DATA_TYPE(pTagColumn->type)) {
×
728
                nTagData = tDataTypes[pTagColumn->type].bytes;
×
729
              }
730
            }
731

732
            if (metaCreateTagIdxKey(e.ctbEntry.suid, pTagColumn->colId, pTagData, nTagData, pTagColumn->type, uid,
77,338✔
733
                                    &pTagIdxKey, &nTagIdxKey) == 0) {
734
              ret = tdbTbDelete(pMeta->pTagIdx, pTagIdxKey, nTagIdxKey, pMeta->txn);
77,338✔
735
              if (ret < 0) {
77,338✔
736
                metaError("vgId:%d, failed to delete tag idx key:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode),
×
737
                          e.name, e.uid, tstrerror(ret));
738
              }
739
            }
740
            metaDestroyTagIdxKey(pTagIdxKey);
77,338✔
741
            pTagIdxKey = NULL;
77,338✔
742
          }
743
        }
744
        tDecoderClear(&tdc);
77,338✔
745
      }
746
      tdbFree(tData);
77,338✔
747
    }
748
  }
749

750
  ret = tdbTbDelete(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), pMeta->txn);
82,690✔
751
  if (ret < 0) {
82,690✔
752
    metaError("vgId:%d, failed to delete table:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
753
              tstrerror(ret));
754
  }
755
  ret = tdbTbDelete(pMeta->pNameIdx, e.name, strlen(e.name) + 1, pMeta->txn);
82,690✔
756
  if (ret < 0) {
82,690✔
757
    metaError("vgId:%d, failed to delete name idx:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
758
              tstrerror(ret));
759
  }
760
  ret = tdbTbDelete(pMeta->pUidIdx, &uid, sizeof(uid), pMeta->txn);
82,690✔
761
  if (ret < 0) {
82,690✔
762
    metaError("vgId:%d, failed to delete uid idx:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
763
              tstrerror(ret));
764
  }
765

766
  if (e.type == TSDB_CHILD_TABLE || e.type == TSDB_NORMAL_TABLE) metaDeleteBtimeIdx(pMeta, &e);
82,690✔
767
  if (e.type == TSDB_NORMAL_TABLE) metaDeleteNcolIdx(pMeta, &e);
82,690✔
768

769
  if (e.type != TSDB_SUPER_TABLE) metaDeleteTtl(pMeta, &e);
82,690✔
770

771
  if (e.type == TSDB_CHILD_TABLE) {
82,690✔
772
    ret =
773
        tdbTbDelete(pMeta->pCtbIdx, &(SCtbIdxKey){.suid = e.ctbEntry.suid, .uid = uid}, sizeof(SCtbIdxKey), pMeta->txn);
77,338✔
774
    if (ret < 0) {
77,338✔
775
      metaError("vgId:%d, failed to delete ctb idx:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
776
                tstrerror(ret));
777
    }
778

779
    --pMeta->pVnode->config.vndStats.numOfCTables;
77,338✔
780
    metaUpdateStbStats(pMeta, e.ctbEntry.suid, -1, 0, -1);
77,338✔
781
    ret = metaUidCacheClear(pMeta, e.ctbEntry.suid);
77,338✔
782
    if (ret < 0) {
77,338✔
783
      metaError("vgId:%d, failed to clear uid cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
×
784
                e.ctbEntry.suid, tstrerror(ret));
785
    }
786
    ret = metaTbGroupCacheClear(pMeta, e.ctbEntry.suid);
77,338✔
787
    if (ret < 0) {
77,338✔
788
      metaError("vgId:%d, failed to clear group cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
×
789
                e.ctbEntry.suid, tstrerror(ret));
790
    }
791
    /*
792
    if (!TSDB_CACHE_NO(pMeta->pVnode->config)) {
793
      tsdbCacheDropTable(pMeta->pVnode->pTsdb, e.uid, e.ctbEntry.suid, NULL);
794
    }
795
    */
796
  } else if (e.type == TSDB_NORMAL_TABLE) {
5,352✔
797
    // drop schema.db (todo)
798

799
    --pMeta->pVnode->config.vndStats.numOfNTables;
5,352✔
800
    pMeta->pVnode->config.vndStats.numOfNTimeSeries -= e.ntbEntry.schemaRow.nCols - 1;
5,352✔
801

802
    /*
803
    if (!TSDB_CACHE_NO(pMeta->pVnode->config)) {
804
      tsdbCacheDropTable(pMeta->pVnode->pTsdb, e.uid, -1, &e.ntbEntry.schemaRow);
805
    }
806
    */
807
  } else if (e.type == TSDB_SUPER_TABLE) {
×
808
    ret = tdbTbDelete(pMeta->pSuidIdx, &e.uid, sizeof(tb_uid_t), pMeta->txn);
×
809
    if (ret < 0) {
×
810
      metaError("vgId:%d, failed to delete suid idx:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
811
                tstrerror(ret));
812
    }
813
    // drop schema.db (todo)
814

815
    ret = metaStatsCacheDrop(pMeta, uid);
×
816
    if (ret < 0) {
×
817
      metaError("vgId:%d, failed to drop stats cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
818
                tstrerror(ret));
819
    }
820
    ret = metaUidCacheClear(pMeta, uid);
×
821
    if (ret < 0) {
×
822
      metaError("vgId:%d, failed to clear uid cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
×
823
                tstrerror(ret));
824
    }
825
    ret = metaStableTagFilterCacheDropSTable(pMeta, uid);
×
826
    if (ret < 0) {
×
827
      metaError("vgId:%d, failed to clear stable tag filter cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
×
828
                e.uid, tstrerror(ret));
829
    }
830
    ret = metaTbGroupCacheClear(pMeta, uid);
×
831
    if (ret < 0) {
×
832
      metaError("vgId:%d, failed to clear group cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name,
×
833
                e.uid, tstrerror(ret));
834
    }
835
    --pMeta->pVnode->config.vndStats.numOfSTables;
×
836
  }
837

838
  ret = metaCacheDrop(pMeta, uid);
82,690✔
839
  if (ret < 0) {
82,690✔
840
    metaError("vgId:%d, failed to drop cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
82,690✔
841
              tstrerror(ret));
842
  }
843

844
  tDecoderClear(&dc);
82,690✔
845
  tdbFree(pData);
82,690✔
846

847
  return 0;
82,690✔
848
}
849

850
static int metaDeleteBtimeIdx(SMeta *pMeta, const SMetaEntry *pME) {
82,690✔
851
  SBtimeIdxKey btimeKey = {0};
82,690✔
852
  if (metaBuildBtimeIdxKey(&btimeKey, pME) < 0) {
82,690✔
853
    return 0;
×
854
  }
855
  return tdbTbDelete(pMeta->pBtimeIdx, &btimeKey, sizeof(btimeKey), pMeta->txn);
82,690✔
856
}
857

858
int metaDeleteNcolIdx(SMeta *pMeta, const SMetaEntry *pME) {
5,352✔
859
  SNcolIdxKey ncolKey = {0};
5,352✔
860
  if (metaBuildNColIdxKey(&ncolKey, pME) < 0) {
5,352✔
861
    return 0;
×
862
  }
863
  return tdbTbDelete(pMeta->pNcolIdx, &ncolKey, sizeof(ncolKey), pMeta->txn);
5,352✔
864
}
865

866
int metaAlterTable(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pMetaRsp) {
12,622,078✔
867
  pMeta->changed = true;
12,622,078✔
868
  switch (pReq->action) {
12,622,078✔
869
    case TSDB_ALTER_TABLE_ADD_COLUMN:
3,687,073✔
870
    case TSDB_ALTER_TABLE_ADD_COLUMN_WITH_COMPRESS_OPTION:
871
    case TSDB_ALTER_TABLE_ADD_COLUMN_WITH_COLUMN_REF:
872
      return metaAddTableColumn(pMeta, version, pReq, pMetaRsp);
3,687,073✔
873
    case TSDB_ALTER_TABLE_DROP_COLUMN:
87,006✔
874
      return metaDropTableColumn(pMeta, version, pReq, pMetaRsp);
87,006✔
875
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES:
510,728✔
876
      return metaAlterTableColumnBytes(pMeta, version, pReq, pMetaRsp);
510,728✔
877
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_NAME:
41,734✔
878
      return metaAlterTableColumnName(pMeta, version, pReq, pMetaRsp);
41,734✔
879
    case TSDB_ALTER_TABLE_UPDATE_MULTI_TABLE_TAG_VAL:
8,064,799✔
880
      return metaUpdateTableMultiTableTagValue(pMeta, version, pReq);
8,064,799✔
881
    case TSDB_ALTER_TABLE_UPDATE_CHILD_TABLE_TAG_VAL:
60,138✔
882
      return metaUpdateTableChildTableTagValue(pMeta, version, pReq);
60,138✔
883
    case TSDB_ALTER_TABLE_UPDATE_OPTIONS:
23,274✔
884
      return metaUpdateTableOptions2(pMeta, version, pReq);
23,274✔
885
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_COMPRESS:
6,349✔
886
      return metaUpdateTableColCompress2(pMeta, version, pReq);
6,349✔
887
    case TSDB_ALTER_TABLE_ALTER_COLUMN_REF:
80,878✔
888
      return metaAlterTableColumnRef(pMeta, version, pReq, pMetaRsp);
80,878✔
889
    case TSDB_ALTER_TABLE_REMOVE_COLUMN_REF:
60,099✔
890
      return metaRemoveTableColumnRef(pMeta, version, pReq, pMetaRsp);
60,099✔
891
    default:
×
892
      return terrno = TSDB_CODE_VND_INVALID_TABLE_ACTION;
×
893
      break;
894
  }
895
}
896

897
static int metaUpdateChangeTime(SMeta *pMeta, tb_uid_t uid, int64_t changeTimeMs) {
21,701,281✔
898
  if (!tsTtlChangeOnWrite) return 0;
21,701,281✔
899

900
  if (changeTimeMs <= 0) {
21,701,281✔
901
    metaWarn("Skip to change ttl deletetion time on write, uid: %" PRId64, uid);
×
902
    return TSDB_CODE_VERSION_NOT_COMPATIBLE;
×
903
  }
904

905
  STtlUpdCtimeCtx ctx = {.uid = uid, .changeTimeMs = changeTimeMs, .pTxn = pMeta->txn};
21,701,281✔
906

907
  return ttlMgrUpdateChangeTime(pMeta->pTtlMgr, &ctx);
21,701,281✔
908
}
909

910
int metaUpdateChangeTimeWithLock(SMeta *pMeta, tb_uid_t uid, int64_t changeTimeMs) {
623,535,081✔
911
  if (!tsTtlChangeOnWrite) return 0;
623,535,081✔
912

913
  metaWLock(pMeta);
21,762,566✔
914
  int ret = metaUpdateChangeTime(pMeta, uid, changeTimeMs);
21,701,281✔
915
  metaULock(pMeta);
21,701,281✔
916
  return ret;
21,701,281✔
917
}
918

919
int metaCreateTagIdxKey(tb_uid_t suid, int32_t cid, const void *pTagData, int32_t nTagData, int8_t type, tb_uid_t uid,
103,181,672✔
920
                        STagIdxKey **ppTagIdxKey, int32_t *nTagIdxKey) {
921
  if (IS_VAR_DATA_TYPE(type)) {
103,181,672✔
922
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + VARSTR_HEADER_SIZE + sizeof(tb_uid_t);
11,801,792✔
923
  } else {
924
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + sizeof(tb_uid_t);
91,379,880✔
925
  }
926

927
  *ppTagIdxKey = (STagIdxKey *)taosMemoryMalloc(*nTagIdxKey);
103,198,142✔
928
  if (*ppTagIdxKey == NULL) {
103,174,670✔
929
    return terrno;
×
930
  }
931

932
  taosSetInt64Aligned(&((*ppTagIdxKey)->suid), suid);
103,158,343✔
933
  (*ppTagIdxKey)->cid = cid;
103,168,928✔
934
  (*ppTagIdxKey)->isNull = (pTagData == NULL) ? 1 : 0;
103,191,072✔
935
  (*ppTagIdxKey)->type = type;
103,168,013✔
936

937
  // refactor
938
  if (IS_VAR_DATA_TYPE(type)) {
103,162,681✔
939
    memcpy((*ppTagIdxKey)->data, (uint16_t *)&nTagData, VARSTR_HEADER_SIZE);
11,852,258✔
940
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE, pTagData, nTagData);
11,822,319✔
941
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE + nTagData), uid);
11,825,669✔
942
  } else {
943
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data, pTagData, nTagData);
91,310,423✔
944
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + nTagData), uid);
91,332,285✔
945
  }
946

947
  return 0;
103,158,826✔
948
}
949

950
void metaDestroyTagIdxKey(STagIdxKey *pTagIdxKey) {
100,101,827✔
951
  if (pTagIdxKey) taosMemoryFree(pTagIdxKey);
100,101,827✔
952
}
100,096,199✔
953

954
static void colCompressDebug(SHashObj *pColCmprObj) {
110,579,538✔
955
  void *p = taosHashIterate(pColCmprObj, NULL);
110,579,538✔
956
  while (p) {
960,548,042✔
957
    uint32_t cmprAlg = *(uint32_t *)p;
849,866,000✔
958
    col_id_t colId = *(col_id_t *)taosHashGetKey(p, NULL);
849,776,514✔
959
    p = taosHashIterate(pColCmprObj, p);
849,794,115✔
960

961
    uint8_t l1, l2, lvl;
850,264,896✔
962
    tcompressDebug(cmprAlg, &l1, &l2, &lvl);
850,284,815✔
963

964
    const char *l1str = columnEncodeStr(l1);
850,247,663✔
965
    const char *l2str = columnCompressStr(l2);
849,976,457✔
966
    const char *lvlstr = columnLevelStr(lvl);
849,924,381✔
967
    metaDebug("colId: %d, encode:%s, compress:%s,level:%s", colId, l1str, l2str, lvlstr);
849,892,752✔
968
  }
969
  return;
110,682,042✔
970
}
971

972
int32_t metaGetColCmpr(SMeta *pMeta, tb_uid_t uid, SHashObj **ppColCmprObj) {
110,665,704✔
973
  int rc = 0;
110,665,704✔
974

975
  SHashObj *pColCmprObj = taosHashInit(32, taosGetDefaultHashFunction(TSDB_DATA_TYPE_SMALLINT), false, HASH_NO_LOCK);
110,665,704✔
976
  if (pColCmprObj == NULL) {
110,669,019✔
977
    pColCmprObj = NULL;
×
978
    return TSDB_CODE_OUT_OF_MEMORY;
×
979
  }
980

981
  void      *pData = NULL;
110,669,019✔
982
  int        nData = 0;
110,683,370✔
983
  SMetaEntry e = {0};
110,682,613✔
984
  SDecoder   dc = {0};
110,677,996✔
985

986
  *ppColCmprObj = NULL;
110,673,420✔
987

988
  metaRLock(pMeta);
110,647,698✔
989
  rc = tdbTbGet(pMeta->pUidIdx, &uid, sizeof(uid), &pData, &nData);
110,696,236✔
990
  if (rc < 0) {
110,677,832✔
991
    taosHashCleanup(pColCmprObj);
51,540✔
992
    metaULock(pMeta);
51,540✔
993
    return TSDB_CODE_FAILED;
51,540✔
994
  }
995
  int64_t version = ((SUidIdxVal *)pData)[0].version;
110,626,292✔
996
  rc = tdbTbGet(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), &pData, &nData);
110,610,402✔
997
  if (rc < 0) {
110,607,573✔
998
    metaULock(pMeta);
×
999
    taosHashCleanup(pColCmprObj);
×
1000
    metaError("failed to get table entry");
×
1001
    return rc;
×
1002
  }
1003

1004
  tDecoderInit(&dc, pData, nData);
110,607,573✔
1005
  rc = metaDecodeEntry(&dc, &e);
110,634,655✔
1006
  if (rc < 0) {
110,548,029✔
1007
    tDecoderClear(&dc);
×
1008
    tdbFree(pData);
×
1009
    metaULock(pMeta);
×
1010
    taosHashCleanup(pColCmprObj);
×
1011
    return rc;
×
1012
  }
1013
  if (withColCompress(e.type)) {
110,548,029✔
1014
    SColCmprWrapper *p = &e.colCmpr;
110,623,444✔
1015
    for (int32_t i = 0; i < p->nCols; i++) {
960,719,457✔
1016
      SColCmpr *pCmpr = &p->pColCmpr[i];
850,080,204✔
1017
      rc = taosHashPut(pColCmprObj, &pCmpr->id, sizeof(pCmpr->id), &pCmpr->alg, sizeof(pCmpr->alg));
850,112,412✔
1018
      if (rc < 0) {
850,096,013✔
1019
        tDecoderClear(&dc);
×
1020
        tdbFree(pData);
×
1021
        metaULock(pMeta);
×
1022
        taosHashCleanup(pColCmprObj);
×
1023
        return rc;
×
1024
      }
1025
    }
1026
  } else {
UNCOV
1027
    tDecoderClear(&dc);
×
1028
    tdbFree(pData);
×
1029
    metaULock(pMeta);
×
1030
    taosHashCleanup(pColCmprObj);
×
1031
    return 0;
×
1032
  }
1033
  tDecoderClear(&dc);
110,482,913✔
1034
  tdbFree(pData);
110,658,969✔
1035
  metaULock(pMeta);
110,631,039✔
1036

1037
  *ppColCmprObj = pColCmprObj;
110,594,376✔
1038
  colCompressDebug(pColCmprObj);
110,604,003✔
1039

1040
  return 0;
110,680,058✔
1041
}
1042
// refactor later
1043
void *metaGetIdx(SMeta *pMeta) { return pMeta->pTagIdx; }
4,273,372✔
1044
void *metaGetIvtIdx(SMeta *pMeta) { return pMeta->pTagIvtIdx; }
4,274,266✔
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