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

taosdata / TDengine / #5025

17 Apr 2026 01:15AM UTC coverage: 73.009% (+0.06%) from 72.954%
#5025

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%)

2432 existing lines in 145 files now uncovered.

273326 of 374375 relevant lines covered (73.01%)

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

50
    SColCmpr *pCol = p + nCols;
3,356,310✔
51
    pCol->id = pSchema->colId;
3,356,310✔
52
    pCol->alg = compress;
3,356,310✔
53
    pWp->nCols = nCols + 1;
3,356,310✔
54
    pWp->version = ver;
3,356,310✔
55
  } else {
56
    for (int32_t i = 0; i < nCols; i++) {
49,730,635✔
57
      SColCmpr *pOCmpr = &pWp->pColCmpr[i];
49,730,635✔
58
      if (pOCmpr->id == pSchema->colId) {
49,730,635✔
59
        int32_t left = (nCols - i - 1) * sizeof(SColCmpr);
81,364✔
60
        if (left) {
81,364✔
61
          memmove(pWp->pColCmpr + i, pWp->pColCmpr + i + 1, left);
57,751✔
62
        }
63
        nCols--;
81,364✔
64
        break;
81,364✔
65
      }
66
    }
67
    pWp->nCols = nCols;
81,364✔
68
    pWp->version = ver;
81,364✔
69
  }
70
  return 0;
3,437,674✔
71
}
72

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

89
int32_t dropTableExtSchema(SMetaEntry *pEntry, int32_t dropColId, int32_t newColNum) {
113,261✔
90
  // no ext schema, no need to drop
91
  if (!pEntry->pExtSchemas) return 0;
113,261✔
92
  if (dropColId == newColNum) {
15,522✔
93
    // drop the last column
94
    pEntry->pExtSchemas[dropColId - 1] = (SExtSchema){0};
5,942✔
95
  } else {
96
    // drop a column in the middle
97
    memmove(pEntry->pExtSchemas + dropColId, pEntry->pExtSchemas + dropColId + 1,
9,580✔
98
            (newColNum - dropColId) * sizeof(SExtSchema));
9,580✔
99
  }
100
  for (int32_t i = 0; i < newColNum; i++) {
66,300✔
101
    if (hasExtSchema(pEntry->pExtSchemas + i)) return 0;
63,362✔
102
  }
103
  taosMemoryFreeClear(pEntry->pExtSchemas);
2,938✔
104
  return 0;
2,938✔
105
}
106

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

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

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

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

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

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

172
  return 0;
11,441,069✔
173
}
174

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

180
  for (int32_t i = 0; i < pSchema->nCols; ++i) {
238,425,532✔
181
    pSchemaExt[i].colId = pSchema->pSchema[i].colId;
237,583,156✔
182
  }
183

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

190
  return TSDB_CODE_SUCCESS;
842,376✔
191
}
192

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

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

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

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

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

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

234
  tstrncpy(pMetaRsp->tbName, tbName, TSDB_TABLE_NAME_LEN);
842,376✔
235
  if (tableType == TSDB_VIRTUAL_NORMAL_TABLE) {
842,376✔
236
    pMetaRsp->tuid = pEntry->uid;
429,199✔
237
  } else if (tableType == TSDB_VIRTUAL_CHILD_TABLE) {
413,177✔
238
    pMetaRsp->tuid = pEntry->uid;
413,177✔
239
    pMetaRsp->suid = pEntry->ctbEntry.suid;
413,177✔
240
  }
241

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

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

262
  return code;
842,376✔
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) {
286,204✔
272
  int32_t code = 0;
286,204✔
273

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

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

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

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

297
  int16_t nCols = taosArrayGetSize(pTagVals);
286,204✔
298
  for (int i = 0; i < nCols; i++) {
690,219✔
299
    STagVal *pTagVal = (STagVal *)taosArrayGet(pTagVals, i);
404,015✔
300
    char     type = pTagVal->type;
404,015✔
301

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

305
    SIndexTerm *term = NULL;
404,015✔
306
    if (type == TSDB_DATA_TYPE_NULL) {
404,015✔
307
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
2,916✔
308
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
401,099✔
309
      if (pTagVal->nData > 0) {
377,890✔
310
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
375,946✔
311
        if (val == NULL) {
375,946✔
312
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
313
        }
314
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
375,946✔
315
        if (len < 0) {
375,946✔
316
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
317
        }
318
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
375,946✔
319
        type = TSDB_DATA_TYPE_VARCHAR;
375,946✔
320
        term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, val, len);
375,946✔
321
        taosMemoryFree(val);
375,946✔
322
      } else if (pTagVal->nData == 0) {
1,944✔
323
        term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, pTagVal->pData, 0);
1,944✔
324
      }
325
    } else if (type == TSDB_DATA_TYPE_DOUBLE) {
23,209✔
326
      double val = *(double *)(&pTagVal->i64);
19,321✔
327
      int    len = sizeof(val);
19,321✔
328
      term = indexTermCreate(suid, ADD_VALUE, type, key, nKey, (const char *)&val, len);
19,321✔
329
    } else if (type == TSDB_DATA_TYPE_BOOL) {
3,888✔
330
      int val = *(int *)(&pTagVal->i64);
3,888✔
331
      int len = sizeof(val);
3,888✔
332
      term = indexTermCreate(suid, ADD_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
3,888✔
333
    }
334

335
    if (term != NULL) {
404,015✔
336
      int32_t ret = indexMultiTermAdd(terms, term);
404,015✔
337
      if (ret < 0) {
404,015✔
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);
286,204✔
347
  indexMultiTermDestroy(terms);
286,204✔
348

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

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

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

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

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

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

390
    SIndexTerm *term = NULL;
224,943✔
391
    if (type == TSDB_DATA_TYPE_NULL) {
224,943✔
392
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_VARCHAR, key, nKey, NULL, 0);
×
393
    } else if (type == TSDB_DATA_TYPE_NCHAR) {
224,943✔
394
      if (pTagVal->nData > 0) {
222,513✔
395
        char *val = taosMemoryCalloc(1, pTagVal->nData + VARSTR_HEADER_SIZE);
222,513✔
396
        if (val == NULL) {
222,513✔
397
          TAOS_CHECK_GOTO(terrno, NULL, _exception);
×
398
        }
399
        int32_t len = taosUcs4ToMbs((TdUcs4 *)pTagVal->pData, pTagVal->nData, val + VARSTR_HEADER_SIZE, NULL);
222,513✔
400
        if (len < 0) {
222,513✔
401
          TAOS_CHECK_GOTO(len, NULL, _exception);
×
402
        }
403
        memcpy(val, (uint16_t *)&len, VARSTR_HEADER_SIZE);
222,513✔
404
        type = TSDB_DATA_TYPE_VARCHAR;
222,513✔
405
        term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, val, len);
222,513✔
406
        taosMemoryFree(val);
222,513✔
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,430✔
411
      double val = *(double *)(&pTagVal->i64);
1,458✔
412
      int    len = sizeof(val);
1,458✔
413
      term = indexTermCreate(suid, DEL_VALUE, type, key, nKey, (const char *)&val, len);
1,458✔
414
    } else if (type == TSDB_DATA_TYPE_BOOL) {
972✔
415
      int val = *(int *)(&pTagVal->i64);
972✔
416
      int len = sizeof(val);
972✔
417
      term = indexTermCreate(suid, DEL_VALUE, TSDB_DATA_TYPE_BOOL, key, nKey, (const char *)&val, len);
972✔
418
    }
419
    if (term != NULL) {
224,943✔
420
      int32_t ret = indexMultiTermAdd(terms, term);
224,943✔
421
      if (ret < 0) {
224,943✔
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,472✔
431
  indexMultiTermDestroy(terms);
120,472✔
432
  taosArrayDestroy(pTagVals);
120,472✔
433
  return code;
120,472✔
434
_exception:
×
435
  indexMultiTermDestroy(terms);
×
436
  taosArrayDestroy(pTagVals);
×
437
#endif
438
  return code;
×
439
}
440

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

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

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

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

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

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

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

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

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

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

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

553
  return 0;
25,793✔
554
}
555

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

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

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

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

576
end:
18,935✔
577
  taosArrayDestroy(tbUids);
25,793✔
578

579
  return code;
25,793✔
580
}
581

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

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

587
  metaULock(pMeta);
13,311,354✔
588

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

593
  return ret;
13,313,325✔
594
}
595

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

847
  return 0;
82,065✔
848
}
849

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

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

866
int metaAlterTable(SMeta *pMeta, int64_t version, SVAlterTbReq *pReq, STableMetaRsp *pMetaRsp) {
12,882,927✔
867
  pMeta->changed = true;
12,882,927✔
868
  switch (pReq->action) {
12,882,927✔
869
    case TSDB_ALTER_TABLE_ADD_COLUMN:
3,739,270✔
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,739,270✔
873
    case TSDB_ALTER_TABLE_DROP_COLUMN:
113,261✔
874
      return metaDropTableColumn(pMeta, version, pReq, pMetaRsp);
113,261✔
875
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES:
514,234✔
876
      return metaAlterTableColumnBytes(pMeta, version, pReq, pMetaRsp);
514,234✔
877
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_NAME:
46,486✔
878
      return metaAlterTableColumnName(pMeta, version, pReq, pMetaRsp);
46,486✔
879
    case TSDB_ALTER_TABLE_UPDATE_MULTI_TABLE_TAG_VAL:
8,231,141✔
880
      return metaUpdateTableMultiTableTagValue(pMeta, version, pReq);
8,231,141✔
881
    case TSDB_ALTER_TABLE_UPDATE_CHILD_TABLE_TAG_VAL:
63,088✔
882
      return metaUpdateTableChildTableTagValue(pMeta, version, pReq);
63,088✔
883
    case TSDB_ALTER_TABLE_UPDATE_OPTIONS:
26,436✔
884
      return metaUpdateTableOptions2(pMeta, version, pReq);
26,436✔
885
    case TSDB_ALTER_TABLE_UPDATE_COLUMN_COMPRESS:
6,433✔
886
      return metaUpdateTableColCompress2(pMeta, version, pReq);
6,433✔
887
    case TSDB_ALTER_TABLE_ALTER_COLUMN_REF:
81,754✔
888
      return metaAlterTableColumnRef(pMeta, version, pReq, pMetaRsp);
81,754✔
889
    case TSDB_ALTER_TABLE_REMOVE_COLUMN_REF:
60,824✔
890
      return metaRemoveTableColumnRef(pMeta, version, pReq, pMetaRsp);
60,824✔
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,785,384✔
898
  if (!tsTtlChangeOnWrite) return 0;
21,785,384✔
899

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

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

910
int metaUpdateChangeTimeWithLock(SMeta *pMeta, tb_uid_t uid, int64_t changeTimeMs) {
626,316,832✔
911
  if (!tsTtlChangeOnWrite) return 0;
626,316,832✔
912

913
  metaWLock(pMeta);
21,798,186✔
914
  int ret = metaUpdateChangeTime(pMeta, uid, changeTimeMs);
21,785,384✔
915
  metaULock(pMeta);
21,785,384✔
916
  return ret;
21,785,384✔
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,
104,257,966✔
920
                        STagIdxKey **ppTagIdxKey, int32_t *nTagIdxKey) {
921
  if (IS_VAR_DATA_TYPE(type)) {
104,257,966✔
922
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + VARSTR_HEADER_SIZE + sizeof(tb_uid_t);
12,017,232✔
923
  } else {
924
    *nTagIdxKey = sizeof(STagIdxKey) + nTagData + sizeof(tb_uid_t);
92,240,734✔
925
  }
926

927
  *ppTagIdxKey = (STagIdxKey *)taosMemoryMalloc(*nTagIdxKey);
104,266,558✔
928
  if (*ppTagIdxKey == NULL) {
104,264,590✔
929
    return terrno;
×
930
  }
931

932
  taosSetInt64Aligned(&((*ppTagIdxKey)->suid), suid);
104,264,049✔
933
  (*ppTagIdxKey)->cid = cid;
104,261,284✔
934
  (*ppTagIdxKey)->isNull = (pTagData == NULL) ? 1 : 0;
104,270,828✔
935
  (*ppTagIdxKey)->type = type;
104,266,354✔
936

937
  // refactor
938
  if (IS_VAR_DATA_TYPE(type)) {
104,260,416✔
939
    memcpy((*ppTagIdxKey)->data, (uint16_t *)&nTagData, VARSTR_HEADER_SIZE);
12,025,386✔
940
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE, pTagData, nTagData);
12,025,822✔
941
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + VARSTR_HEADER_SIZE + nTagData), uid);
12,024,067✔
942
  } else {
943
    if (pTagData != NULL) memcpy((*ppTagIdxKey)->data, pTagData, nTagData);
92,235,030✔
944
    taosSetInt64Aligned((tb_uid_t *)((*ppTagIdxKey)->data + nTagData), uid);
92,241,497✔
945
  }
946

947
  return 0;
104,267,419✔
948
}
949

950
void metaDestroyTagIdxKey(STagIdxKey *pTagIdxKey) {
100,921,089✔
951
  if (pTagIdxKey) taosMemoryFree(pTagIdxKey);
100,921,089✔
952
}
100,914,950✔
953

954
static void colCompressDebug(SHashObj *pColCmprObj) {
111,513,274✔
955
  void *p = taosHashIterate(pColCmprObj, NULL);
111,513,274✔
956
  while (p) {
966,352,011✔
957
    uint32_t cmprAlg = *(uint32_t *)p;
854,804,085✔
958
    col_id_t colId = *(col_id_t *)taosHashGetKey(p, NULL);
854,810,442✔
959
    p = taosHashIterate(pColCmprObj, p);
854,799,910✔
960

961
    uint8_t l1, l2, lvl;
854,915,689✔
962
    tcompressDebug(cmprAlg, &l1, &l2, &lvl);
854,933,017✔
963

964
    const char *l1str = columnEncodeStr(l1);
854,907,118✔
965
    const char *l2str = columnCompressStr(l2);
854,827,465✔
966
    const char *lvlstr = columnLevelStr(lvl);
854,830,714✔
967
    metaDebug("colId: %d, encode:%s, compress:%s,level:%s", colId, l1str, l2str, lvlstr);
854,816,552✔
968
  }
969
  return;
111,547,926✔
970
}
971

972
int32_t metaGetColCmpr(SMeta *pMeta, tb_uid_t uid, SHashObj **ppColCmprObj) {
111,581,825✔
973
  int rc = 0;
111,581,825✔
974

975
  SHashObj *pColCmprObj = taosHashInit(32, taosGetDefaultHashFunction(TSDB_DATA_TYPE_SMALLINT), false, HASH_NO_LOCK);
111,581,825✔
976
  if (pColCmprObj == NULL) {
111,576,333✔
977
    pColCmprObj = NULL;
×
978
    return TSDB_CODE_OUT_OF_MEMORY;
×
979
  }
980

981
  void      *pData = NULL;
111,576,333✔
982
  int        nData = 0;
111,579,058✔
983
  SMetaEntry e = {0};
111,583,722✔
984
  SDecoder   dc = {0};
111,581,732✔
985

986
  *ppColCmprObj = NULL;
111,585,364✔
987

988
  metaRLock(pMeta);
111,570,465✔
989
  rc = tdbTbGet(pMeta->pUidIdx, &uid, sizeof(uid), &pData, &nData);
111,594,661✔
990
  if (rc < 0) {
111,585,107✔
991
    taosHashCleanup(pColCmprObj);
52,733✔
992
    metaULock(pMeta);
52,733✔
993
    return TSDB_CODE_FAILED;
52,733✔
994
  }
995
  int64_t version = ((SUidIdxVal *)pData)[0].version;
111,532,374✔
996
  rc = tdbTbGet(pMeta->pTbDb, &(STbDbKey){.version = version, .uid = uid}, sizeof(STbDbKey), &pData, &nData);
111,532,673✔
997
  if (rc < 0) {
111,526,440✔
998
    metaULock(pMeta);
×
999
    taosHashCleanup(pColCmprObj);
×
1000
    metaError("failed to get table entry");
×
1001
    return rc;
×
1002
  }
1003

1004
  tDecoderInit(&dc, pData, nData);
111,526,440✔
1005
  rc = metaDecodeEntry(&dc, &e);
111,523,174✔
1006
  if (rc < 0) {
111,523,164✔
1007
    tDecoderClear(&dc);
×
1008
    tdbFree(pData);
×
1009
    metaULock(pMeta);
×
1010
    taosHashCleanup(pColCmprObj);
×
1011
    return rc;
×
1012
  }
1013
  if (withColCompress(e.type)) {
111,523,164✔
1014
    SColCmprWrapper *p = &e.colCmpr;
111,527,599✔
1015
    for (int32_t i = 0; i < p->nCols; i++) {
966,418,106✔
1016
      SColCmpr *pCmpr = &p->pColCmpr[i];
854,878,339✔
1017
      rc = taosHashPut(pColCmprObj, &pCmpr->id, sizeof(pCmpr->id), &pCmpr->alg, sizeof(pCmpr->alg));
854,868,412✔
1018
      if (rc < 0) {
854,890,507✔
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);
111,511,707✔
1034
  tdbFree(pData);
111,543,863✔
1035
  metaULock(pMeta);
111,527,777✔
1036

1037
  *ppColCmprObj = pColCmprObj;
111,514,390✔
1038
  colCompressDebug(pColCmprObj);
111,520,863✔
1039

1040
  return 0;
111,547,019✔
1041
}
1042
// refactor later
1043
void *metaGetIdx(SMeta *pMeta) { return pMeta->pTagIdx; }
4,495,218✔
1044
void *metaGetIvtIdx(SMeta *pMeta) { return pMeta->pTagIvtIdx; }
4,495,218✔
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