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

taosdata / TDengine / #5027

17 Apr 2026 01:15AM UTC coverage: 72.996% (+0.03%) from 72.966%
#5027

push

travis-ci

web-flow
fix: replace \s with [[:space:]] in shell regex for macOS BSD compat (#35162)

6 of 7 new or added lines in 2 files covered. (85.71%)

404 existing lines in 122 files now uncovered.

273279 of 374375 relevant lines covered (73.0%)

130951667.08 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,399,586✔
41
  int32_t nCols = pWp->nCols;
3,399,586✔
42
  int32_t ver = pWp->version;
3,399,586✔
43
  if (add) {
3,399,586✔
44
    SColCmpr *p = taosMemoryRealloc(pWp->pColCmpr, sizeof(SColCmpr) * (nCols + 1));
3,337,454✔
45
    if (p == NULL) {
3,337,454✔
46
      return terrno;
×
47
    }
48
    pWp->pColCmpr = p;
3,337,454✔
49

50
    SColCmpr *pCol = p + nCols;
3,337,454✔
51
    pCol->id = pSchema->colId;
3,337,454✔
52
    pCol->alg = compress;
3,337,454✔
53
    pWp->nCols = nCols + 1;
3,337,454✔
54
    pWp->version = ver;
3,337,454✔
55
  } else {
56
    for (int32_t i = 0; i < nCols; i++) {
14,116,270✔
57
      SColCmpr *pOCmpr = &pWp->pColCmpr[i];
14,116,270✔
58
      if (pOCmpr->id == pSchema->colId) {
14,116,270✔
59
        int32_t left = (nCols - i - 1) * sizeof(SColCmpr);
62,132✔
60
        if (left) {
62,132✔
61
          memmove(pWp->pColCmpr + i, pWp->pColCmpr + i + 1, left);
40,616✔
62
        }
63
        nCols--;
62,132✔
64
        break;
62,132✔
65
      }
66
    }
67
    pWp->nCols = nCols;
62,132✔
68
    pWp->version = ver;
62,132✔
69
  }
70
  return 0;
3,399,586✔
71
}
72

73
int32_t addTableExtSchema(SMetaEntry *pEntry, const SSchema *pColumn, int32_t newColNum, SExtSchema *pExtSchema) {
3,395,655✔
74
  // no need to add ext schema when no column needs ext schemas
75
  if (!HAS_TYPE_MOD(pColumn) && !pEntry->pExtSchemas) return 0;
3,395,655✔
76
  if (!pEntry->pExtSchemas) {
14,908✔
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,292✔
80
  } else {
81
    // already has columns with ext schema
82
    pEntry->pExtSchemas = (SExtSchema *)taosMemoryRealloc(pEntry->pExtSchemas, sizeof(SExtSchema) * newColNum);
12,616✔
83
  }
84
  if (!pEntry->pExtSchemas) return terrno;
14,908✔
85
  pEntry->pExtSchemas[newColNum - 1] = *pExtSchema;
14,908✔
86
  return 0;
14,908✔
87
}
88

89
int32_t dropTableExtSchema(SMetaEntry *pEntry, int32_t dropColId, int32_t newColNum) {
93,938✔
90
  // no ext schema, no need to drop
91
  if (!pEntry->pExtSchemas) return 0;
93,938✔
92
  if (dropColId == newColNum) {
10,581✔
93
    // drop the last column
94
    pEntry->pExtSchemas[dropColId - 1] = (SExtSchema){0};
3,825✔
95
  } else {
96
    // drop a column in the middle
97
    memmove(pEntry->pExtSchemas + dropColId, pEntry->pExtSchemas + dropColId + 1,
6,756✔
98
            (newColNum - dropColId) * sizeof(SExtSchema));
6,756✔
99
  }
100
  for (int32_t i = 0; i < newColNum; i++) {
39,498✔
101
    if (hasExtSchema(pEntry->pExtSchemas + i)) return 0;
37,970✔
102
  }
103
  taosMemoryFreeClear(pEntry->pExtSchemas);
1,528✔
104
  return 0;
1,528✔
105
}
106

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

116
    SColRef *pCol = p + nCols;
64,717✔
117
    if (NULL == pColRef) {
64,717✔
118
      pCol->hasRef = false;
6,516✔
119
      pCol->id = pSchema->colId;
6,516✔
120
    } else {
121
      pCol->hasRef = pColRef->hasRef;
58,201✔
122
      pCol->id = pSchema->colId;
58,201✔
123
      if (pCol->hasRef) {
58,201✔
124
        tstrncpy(pCol->refDbName, pColRef->refDbName, TSDB_DB_NAME_LEN);
24,646✔
125
        tstrncpy(pCol->refTableName, pColRef->refTableName, TSDB_TABLE_NAME_LEN);
24,646✔
126
        tstrncpy(pCol->refColName, pColRef->refColName, TSDB_COL_NAME_LEN);
24,646✔
127
      }
128
    }
129
    pWp->nCols = nCols + 1;
64,717✔
130
    pWp->version++;
64,717✔
131
  } else {
132
    for (int32_t i = 0; i < nCols; i++) {
38,273,759✔
133
      SColRef *pOColRef = &pWp->pColRef[i];
38,273,759✔
134
      if (pOColRef->id == pSchema->colId) {
38,273,759✔
135
        int32_t left = (nCols - i - 1) * sizeof(SColRef);
36,419✔
136
        if (left) {
36,419✔
137
          memmove(pWp->pColRef + i, pWp->pColRef + i + 1, left);
33,161✔
138
        }
139
        nCols--;
36,419✔
140
        break;
36,419✔
141
      }
142
    }
143
    pWp->nCols = nCols;
36,419✔
144
    pWp->version++;
36,419✔
145
  }
146
  return 0;
101,136✔
147
}
148

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

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

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

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

172
  return 0;
11,371,913✔
173
}
174

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

180
  for (int32_t i = 0; i < pSchema->nCols; ++i) {
236,812,888✔
181
    pSchemaExt[i].colId = pSchema->pSchema[i].colId;
235,973,304✔
182
  }
183

184
  if (pExtSchemas != NULL) {
839,584✔
185
    for (int32_t i = 0; i < pSchema->nCols; ++i) {
156,777✔
186
      pSchemaExt[i].typeMod = pExtSchemas[i].typeMod;
140,157✔
187
    }
188
  }
189

190
  return TSDB_CODE_SUCCESS;
839,584✔
191
}
192

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

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

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

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

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

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

234
  tstrncpy(pMetaRsp->tbName, tbName, TSDB_TABLE_NAME_LEN);
839,584✔
235
  if (tableType == TSDB_VIRTUAL_NORMAL_TABLE) {
839,584✔
236
    pMetaRsp->tuid = pEntry->uid;
427,664✔
237
  } else if (tableType == TSDB_VIRTUAL_CHILD_TABLE) {
411,920✔
238
    pMetaRsp->tuid = pEntry->uid;
411,920✔
239
    pMetaRsp->suid = pEntry->ctbEntry.suid;
411,920✔
240
  }
241

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

248
  // Populate tag references
249
  if (pRef->nTagRefs > 0 && pRef->pTagRef) {
839,584✔
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;
839,584✔
259
    pMetaRsp->numOfTagRefs = 0;
839,584✔
260
  }
261

262
  return code;
839,584✔
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) {
279,129✔
272
  int32_t code = 0;
279,129✔
273

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

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

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

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

297
  int16_t nCols = taosArrayGetSize(pTagVals);
279,129✔
298
  for (int i = 0; i < nCols; i++) {
675,782✔
299
    STagVal *pTagVal = (STagVal *)taosArrayGet(pTagVals, i);
396,653✔
300
    char     type = pTagVal->type;
396,653✔
301

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

305
    SIndexTerm *term = NULL;
396,653✔
306
    if (type == TSDB_DATA_TYPE_NULL) {
396,653✔
307
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
2,892✔
308
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
393,761✔
309
      if (pTagVal->nData > 0) {
370,586✔
310
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
368,658✔
311
        if (val == NULL) {
368,658✔
312
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
313
        }
314
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
368,658✔
315
        if (len < 0) {
368,658✔
316
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
317
        }
318
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
368,658✔
319
        type = TSDB_DATA_TYPE_VARCHAR;
368,658✔
320
        term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, val, len);
368,658✔
321
        taosMemoryFree(val);
368,658✔
322
      } else if (pTagVal->nData == 0) {
1,928✔
323
        term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, pTagVal->pData, 0);
1,928✔
324
      }
325
    } else if (type == TSDB_DATA_TYPE_DOUBLE) {
23,175✔
326
      double val = *(double *)(&pTagVal->i64);
19,319✔
327
      int    len = sizeof(val);
19,319✔
328
      term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, (const char *)&val, len);
19,319✔
329
    } else if (type == TSDB_DATA_TYPE_BOOL) {
3,856✔
330
      int val = *(int *)(&pTagVal->i64);
3,856✔
331
      int len = sizeof(val);
3,856✔
332
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
3,856✔
333
    }
334

335
    if (term != NULL) {
396,653✔
336
      int32_t ret = indexMultiTermAdd(terms, term);
396,653✔
337
      if (ret < 0) {
396,653✔
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);
279,129✔
347
  indexMultiTermDestroy(terms);
279,129✔
348

349
  taosArrayDestroy(pTagVals);
279,129✔
350
  return code;
279,129✔
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) {
120,270✔
358
int32_t code = 0;
120,270✔
359
#ifdef USE_INVERTED_INDEX
360
  if (pMeta->pTagIvtIdx == NULL || pCtbEntry == NULL) {
120,270✔
361
    return TSDB_CODE_INVALID_PARA;
×
362
  }
363
  void       *data = pCtbEntry->ctbEntry.pTags;
120,270✔
364
  const char *tagName = pSchema->name;
120,270✔
365

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

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

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

382
  int16_t nCols = taosArrayGetSize(pTagVals);
120,270✔
383
  for (int i = 0; i < nCols; i++) {
344,832✔
384
    STagVal *pTagVal = (STagVal *)taosArrayGet(pTagVals, i);
224,562✔
385
    char     type = pTagVal->type;
224,562✔
386

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

390
    SIndexTerm *term = NULL;
224,562✔
391
    if (type == TSDB_DATA_TYPE_NULL) {
224,562✔
392
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
×
393
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
224,562✔
394
      if (pTagVal->nData > 0) {
222,152✔
395
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
222,152✔
396
        if (val == NULL) {
222,152✔
397
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
398
        }
399
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
222,152✔
400
        if (len < 0) {
222,152✔
401
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
402
        }
403
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
222,152✔
404
        type = TSDB_DATA_TYPE_VARCHAR;
222,152✔
405
        term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, val, len);
222,152✔
406
        taosMemoryFree(val);
222,152✔
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,410✔
411
      double val = *(double *)(&pTagVal->i64);
1,446✔
412
      int    len = sizeof(val);
1,446✔
413
      term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, (const char *)&val, len);
1,446✔
414
    } else if (type == TSDB_DATA_TYPE_BOOL) {
964✔
415
      int val = *(int *)(&pTagVal->i64);
964✔
416
      int len = sizeof(val);
964✔
417
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
964✔
418
    }
419
    if (term != NULL) {
224,562✔
420
      int32_t ret = indexMultiTermAdd(terms, term);
224,562✔
421
      if (ret < 0) {
224,562✔
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);
120,270✔
431
  indexMultiTermDestroy(terms);
120,270✔
432
  taosArrayDestroy(pTagVals);
120,270✔
433
  return code;
120,270✔
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,585✔
442
  int32_t code = 0;
19,585✔
443
  if (taosArrayGetSize(tbUids) == 0) return TSDB_CODE_SUCCESS;
19,585✔
444

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

451
  metaWLock(pMeta);
19,585✔
452
  for (int i = 0; i < taosArrayGetSize(tbUids); ++i) {
101,858✔
453
    tb_uid_t uid = *(tb_uid_t *)taosArrayGet(tbUids, i);
82,273✔
454
    tb_uid_t suid = 0;
82,273✔
455
    int8_t   sysTbl = 0;
82,273✔
456
    int      type;
82,273✔
457
    code = metaDropTableByUid(pMeta, uid, &type, &suid, &sysTbl);
82,273✔
458
    if (code) return code;
82,273✔
459
    if (!sysTbl && type == TSDB_CHILD_TABLE && suid != 0 && suidHash) {
82,273✔
460
      int64_t *pVal = tSimpleHashGet(suidHash, &suid, sizeof(tb_uid_t));
76,298✔
461
      if (pVal) {
76,298✔
462
        nCtbDropped = *pVal + 1;
59,854✔
463
      } else {
464
        nCtbDropped = 1;
16,444✔
465
      }
466
      code = tSimpleHashPut(suidHash, &suid, sizeof(tb_uid_t), &nCtbDropped, sizeof(int64_t));
76,298✔
467
      if (code) return code;
76,298✔
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,273✔
475
  }
476
  metaULock(pMeta);
19,585✔
477

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

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

498
static int32_t metaFilterTableByHash(SMeta *pMeta, SArray *uidList) {
25,665✔
499
  int32_t code = 0;
25,665✔
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,665✔
505
  code = tdbTbcOpen(pMeta->pTbDb, &pCur, NULL);
25,665✔
506
  if (code < 0) {
25,665✔
507
    return code;
×
508
  }
509

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

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

519
  while (1) {
183,968✔
520
    int32_t ret = tdbTbcNext(pCur, &pKey, &nKey, &pData, &nData);
209,633✔
521
    if (ret < 0) {
209,633✔
522
      break;
25,665✔
523
    }
524

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

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

553
  return 0;
25,665✔
554
}
555

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

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

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

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

576
end:
19,585✔
577
  taosArrayDestroy(tbUids);
25,665✔
578

579
  return code;
25,665✔
580
}
581

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

585
  int ret = ttlMgrFindExpired(pMeta->pTtlMgr, timePointMs, tbUids, ttlDropMaxCount);
13,379,150✔
586

587
  metaULock(pMeta);
13,361,113✔
588

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

593
  return ret;
13,368,311✔
594
}
595

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

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

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

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

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

631
  int32_t ret = ttlMgrDeleteTtl(pMeta->pTtlMgr, &ctx);
82,273✔
632
  if (ret < 0) {
82,273✔
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,273✔
637
}
638

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

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

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

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

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

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

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

679
        tDecoderInit(&tdc, tData, tLen);
76,298✔
680
        ret = metaDecodeEntry(&tdc, &stbEntry);
76,298✔
681
        if (ret < 0) {
76,298✔
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;
76,298✔
689
        
690
        ret = metaStableTagFilterCacheUpdateUid(
76,298✔
691
          pMeta, &e, &stbEntry, STABLE_TAG_FILTER_CACHE_DROP_TABLE);
692
        if (ret < 0) {
76,298✔
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;
76,298✔
699
        SSchemaWrapper *pTagSchema = &stbEntry.stbEntry.schemaTag;
76,298✔
700
        if (pTagSchema->nCols == 1 && pTagSchema->pSchema[0].type == TSDB_DATA_TYPE_JSON) {
76,298✔
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++) {
395,202✔
709
            pTagColumn = &stbEntry.stbEntry.schemaTag.pSchema[i];
318,904✔
710
            if (!IS_IDX_ON(pTagColumn)) continue;
318,904✔
711
            STagIdxKey *pTagIdxKey = NULL;
76,298✔
712
            int32_t     nTagIdxKey;
76,298✔
713

714
            const void *pTagData = NULL;
76,298✔
715
            int32_t     nTagData = 0;
76,298✔
716

717
            STagVal tagVal = {.cid = pTagColumn->colId};
76,298✔
718
            if (tTagGet((const STag *)e.ctbEntry.pTags, &tagVal)) {
76,298✔
719
              if (IS_VAR_DATA_TYPE(pTagColumn->type)) {
76,298✔
720
                pTagData = tagVal.pData;
×
721
                nTagData = (int32_t)tagVal.nData;
×
722
              } else {
723
                pTagData = &(tagVal.i64);
76,298✔
724
                nTagData = tDataTypes[pTagColumn->type].bytes;
76,298✔
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,
76,298✔
733
                                    &pTagIdxKey, &nTagIdxKey) == 0) {
734
              ret = tdbTbDelete(pMeta->pTagIdx, pTagIdxKey, nTagIdxKey, pMeta->txn);
76,298✔
735
              if (ret < 0) {
76,298✔
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);
76,298✔
741
            pTagIdxKey = NULL;
76,298✔
742
          }
743
        }
744
        tDecoderClear(&tdc);
76,298✔
745
      }
746
      tdbFree(tData);
76,298✔
747
    }
748
  }
749

750
  ret = tdbTbDelete(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), pMeta->txn);
82,273✔
751
  if (ret < 0) {
82,273✔
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,273✔
756
  if (ret < 0) {
82,273✔
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,273✔
761
  if (ret < 0) {
82,273✔
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,273✔
767
  if (e.type == TSDB_NORMAL_TABLE) metaDeleteNcolIdx(pMeta, &e);
82,273✔
768

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

771
  if (e.type == TSDB_CHILD_TABLE) {
82,273✔
772
    ret =
773
        tdbTbDelete(pMeta->pCtbIdx, &(SCtbIdxKey){.suid = e.ctbEntry.suid, .uid = uid}, sizeof(SCtbIdxKey), pMeta->txn);
76,298✔
774
    if (ret < 0) {
76,298✔
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;
76,298✔
780
    metaUpdateStbStats(pMeta, e.ctbEntry.suid, -1, 0, -1);
76,298✔
781
    ret = metaUidCacheClear(pMeta, e.ctbEntry.suid);
76,298✔
782
    if (ret < 0) {
76,298✔
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);
76,298✔
787
    if (ret < 0) {
76,298✔
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,975✔
797
    // drop schema.db (todo)
798

799
    --pMeta->pVnode->config.vndStats.numOfNTables;
5,975✔
800
    pMeta->pVnode->config.vndStats.numOfNTimeSeries -= e.ntbEntry.schemaRow.nCols - 1;
5,975✔
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,273✔
839
  if (ret < 0) {
82,273✔
840
    metaError("vgId:%d, failed to drop cache:%s uid:%" PRId64 " since %s", TD_VID(pMeta->pVnode), e.name, e.uid,
82,273✔
841
              tstrerror(ret));
842
  }
843

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

847
  return 0;
82,273✔
848
}
849

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

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

866
int metaAlterTable(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pMetaRsp) {
12,851,949✔
867
  pMeta->changed = true;
12,851,949✔
868
  switch (pReq->action) {
12,851,949✔
869
    case TSDB_ALTER_TABLE_ADD_COLUMN:
3,730,797✔
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,730,797✔
873
    case TSDB_ALTER_TABLE_DROP_COLUMN:
93,938✔
874
      return metaDropTableColumn(pMeta, version, pReq, pMetaRsp);
93,938✔
875
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES:
521,770✔
876
      return metaAlterTableColumnBytes(pMeta, version, pReq, pMetaRsp);
521,770✔
877
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_NAME:
46,451✔
878
      return metaAlterTableColumnName(pMeta, version, pReq, pMetaRsp);
46,451✔
879
    case TSDB_ALTER_TABLE_UPDATE_MULTI_TABLE_TAG_VAL:
8,221,130✔
880
      return metaUpdateTableMultiTableTagValue(pMeta, version, pReq);
8,221,130✔
881
    case TSDB_ALTER_TABLE_UPDATE_CHILD_TABLE_TAG_VAL:
62,846✔
882
      return metaUpdateTableChildTableTagValue(pMeta, version, pReq);
62,846✔
883
    case TSDB_ALTER_TABLE_UPDATE_OPTIONS:
26,448✔
884
      return metaUpdateTableOptions2(pMeta, version, pReq);
26,448✔
885
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_COMPRESS:
6,427✔
886
      return metaUpdateTableColCompress2(pMeta, version, pReq);
6,427✔
887
    case TSDB_ALTER_TABLE_ALTER_COLUMN_REF:
81,511✔
888
      return metaAlterTableColumnRef(pMeta, version, pReq, pMetaRsp);
81,511✔
889
    case TSDB_ALTER_TABLE_REMOVE_COLUMN_REF:
60,631✔
890
      return metaRemoveTableColumnRef(pMeta, version, pReq, pMetaRsp);
60,631✔
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,724,850✔
898
  if (!tsTtlChangeOnWrite) return 0;
21,724,850✔
899

900
  if (changeTimeMs <= 0) {
21,724,850✔
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,724,850✔
906

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

910
int metaUpdateChangeTimeWithLock(SMeta *pMeta, tb_uid_t uid, int64_t changeTimeMs) {
625,478,105✔
911
  if (!tsTtlChangeOnWrite) return 0;
625,478,105✔
912

913
  metaWLock(pMeta);
21,739,875✔
914
  int ret = metaUpdateChangeTime(pMeta, uid, changeTimeMs);
21,724,850✔
915
  metaULock(pMeta);
21,724,850✔
916
  return ret;
21,724,850✔
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,265,684✔
920
                        STagIdxKey **ppTagIdxKey, int32_t *nTagIdxKey) {
921
  if (IS_VAR_DATA_TYPE(type)) {
103,265,684✔
922
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + VARSTR_HEADER_SIZE + sizeof(tb_uid_t);
11,970,346✔
923
  } else {
924
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + sizeof(tb_uid_t);
91,295,338✔
925
  }
926

927
  *ppTagIdxKey = (STagIdxKey *)taosMemoryMalloc(*nTagIdxKey);
103,272,753✔
928
  if (*ppTagIdxKey == NULL) {
103,274,454✔
929
    return terrno;
×
930
  }
931

932
  taosSetInt64Aligned(&((*ppTagIdxKey)->suid), suid);
103,274,284✔
933
  (*ppTagIdxKey)->cid = cid;
103,267,540✔
934
  (*ppTagIdxKey)->isNull = (pTagData == NULL) ? 1 : 0;
103,280,217✔
935
  (*ppTagIdxKey)->type = type;
103,270,320✔
936

937
  // refactor
938
  if (IS_VAR_DATA_TYPE(type)) {
103,276,638✔
939
    memcpy((*ppTagIdxKey)->data, (uint16_t *)&nTagData, VARSTR_HEADER_SIZE);
11,985,816✔
940
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE, pTagData, nTagData);
11,980,161✔
941
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE + nTagData), uid);
11,979,333✔
942
  } else {
943
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data, pTagData, nTagData);
91,290,822✔
944
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + nTagData), uid);
91,293,805✔
945
  }
946

947
  return 0;
103,275,064✔
948
}
949

950
void metaDestroyTagIdxKey(STagIdxKey *pTagIdxKey) {
100,025,670✔
951
  if (pTagIdxKey) taosMemoryFree(pTagIdxKey);
100,025,670✔
952
}
100,019,657✔
953

954
static void colCompressDebug(SHashObj *pColCmprObj) {
110,100,900✔
955
  void *p = taosHashIterate(pColCmprObj, NULL);
110,100,900✔
956
  while (p) {
959,102,482✔
957
    uint32_t cmprAlg = *(uint32_t *)p;
848,975,629✔
958
    col_id_t colId = *(col_id_t *)taosHashGetKey(p, NULL);
848,972,345✔
959
    p = taosHashIterate(pColCmprObj, p);
848,972,356✔
960

961
    uint8_t l1, l2, lvl;
849,056,733✔
962
    tcompressDebug(cmprAlg, &l1, &l2, &lvl);
849,067,220✔
963

964
    const char *l1str = columnEncodeStr(l1);
849,051,023✔
965
    const char *l2str = columnCompressStr(l2);
848,988,229✔
966
    const char *lvlstr = columnLevelStr(lvl);
848,976,464✔
967
    metaDebug("colId: %d, encode:%s, compress:%s,level:%s", colId, l1str, l2str, lvlstr);
848,953,777✔
968
  }
969
  return;
110,126,853✔
970
}
971

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

975
  SHashObj *pColCmprObj = taosHashInit(32, taosGetDefaultHashFunction(TSDB_DATA_TYPE_SMALLINT), false, HASH_NO_LOCK);
110,168,922✔
976
  if (pColCmprObj == NULL) {
110,165,950✔
977
    pColCmprObj = NULL;
×
978
    return TSDB_CODE_OUT_OF_MEMORY;
×
979
  }
980

981
  void      *pData = NULL;
110,165,950✔
982
  int        nData = 0;
110,167,121✔
983
  SMetaEntry e = {0};
110,169,096✔
984
  SDecoder   dc = {0};
110,168,120✔
985

986
  *ppColCmprObj = NULL;
110,167,905✔
987

988
  metaRLock(pMeta);
110,162,406✔
989
  rc = tdbTbGet(pMeta->pUidIdx, &uid, sizeof(uid), &pData, &nData);
110,171,114✔
990
  if (rc < 0) {
110,166,025✔
991
    taosHashCleanup(pColCmprObj);
51,828✔
992
    metaULock(pMeta);
51,828✔
993
    return TSDB_CODE_FAILED;
51,828✔
994
  }
995
  int64_t version = ((SUidIdxVal *)pData)[0].version;
110,114,197✔
996
  rc = tdbTbGet(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), &pData, &nData);
110,109,016✔
997
  if (rc < 0) {
110,105,592✔
998
    metaULock(pMeta);
×
999
    taosHashCleanup(pColCmprObj);
×
1000
    metaError("failed to get table entry");
×
1001
    return rc;
×
1002
  }
1003

1004
  tDecoderInit(&dc, pData, nData);
110,105,592✔
1005
  rc = metaDecodeEntry(&dc, &e);
110,099,266✔
1006
  if (rc < 0) {
110,104,349✔
1007
    tDecoderClear(&dc);
×
1008
    tdbFree(pData);
×
1009
    metaULock(pMeta);
×
1010
    taosHashCleanup(pColCmprObj);
×
1011
    return rc;
×
1012
  }
1013
  if (withColCompress(e.type)) {
110,104,349✔
1014
    SColCmprWrapper *p = &e.colCmpr;
110,108,507✔
1015
    for (int32_t i = 0; i < p->nCols; i++) {
959,132,660✔
1016
      SColCmpr *pCmpr = &p->pColCmpr[i];
849,012,597✔
1017
      rc = taosHashPut(pColCmprObj, &pCmpr->id, sizeof(pCmpr->id), &pCmpr->alg, sizeof(pCmpr->alg));
849,007,129✔
1018
      if (rc < 0) {
849,024,153✔
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,086,642✔
1034
  tdbFree(pData);
110,114,311✔
1035
  metaULock(pMeta);
110,109,819✔
1036

1037
  *ppColCmprObj = pColCmprObj;
110,101,702✔
1038
  colCompressDebug(pColCmprObj);
110,106,381✔
1039

1040
  return 0;
110,125,217✔
1041
}
1042
// refactor later
1043
void *metaGetIdx(SMeta *pMeta) { return pMeta->pTagIdx; }
4,408,502✔
1044
void *metaGetIvtIdx(SMeta *pMeta) { return pMeta->pTagIvtIdx; }
4,408,502✔
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