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

H
refact  
Hongze Cheng 已提交
16 17
#ifndef _TD_TSDB_H_
#define _TD_TSDB_H_
H
refact  
Hongze Cheng 已提交
18

H
more  
Hongze Cheng 已提交
19
#include "mallocator.h"
H
more  
Hongze Cheng 已提交
20
#include "meta.h"
H
more  
Hongze Cheng 已提交
21

H
refact  
Hongze Cheng 已提交
22 23 24 25
#ifdef __cplusplus
extern "C" {
#endif

H
Hongze Cheng 已提交
26 27 28 29 30 31 32 33 34 35 36
typedef struct SDataStatis {
  int16_t colId;
  int64_t sum;
  int64_t max;
  int64_t min;
  int16_t maxIndex;
  int16_t minIndex;
  int16_t numOfNull;
} SDataStatis;

typedef struct STable {
H
more  
Hongze Cheng 已提交
37
  uint64_t  tid;
H
Hongze Cheng 已提交
38 39 40 41 42 43 44
  uint64_t  uid;
  STSchema *pSchema;
} STable;

#define TABLE_TID(t) (t)->tid
#define TABLE_UID(t) (t)->uid

H
refact  
Hongze Cheng 已提交
45
// TYPES EXPOSED
H
more  
Hongze Cheng 已提交
46 47 48
typedef struct STsdb STsdb;

typedef struct STsdbCfg {
H
Hongze Cheng 已提交
49
  int8_t   precision;
H
more  
Hongze Cheng 已提交
50
  uint64_t lruCacheSize;
H
Hongze Cheng 已提交
51
  int32_t  daysPerFile;
H
Hongze Cheng 已提交
52 53 54 55 56 57
  int32_t  minRowsPerFileBlock;
  int32_t  maxRowsPerFileBlock;
  int32_t  keep;
  int32_t  keep1;
  int32_t  keep2;
  int8_t   update;
H
more  
Hongze Cheng 已提交
58
  int8_t   compression;
H
more  
Hongze Cheng 已提交
59
} STsdbCfg;
H
more  
Hongze Cheng 已提交
60

H
refact  
Hongze Cheng 已提交
61
// STsdb
H
more  
Hongze Cheng 已提交
62
STsdb *tsdbOpen(const char *path, int32_t vgId, const STsdbCfg *pTsdbCfg, SMemAllocatorFactory *pMAF, SMeta *pMeta);
H
more  
Hongze Cheng 已提交
63
void   tsdbClose(STsdb *);
H
refact  
Hongze Cheng 已提交
64
void   tsdbRemove(const char *path);
H
Hongze Cheng 已提交
65
int    tsdbInsertData(STsdb *pTsdb, SSubmitMsg *pMsg, SSubmitRsp *pRsp);
H
more  
Hongze Cheng 已提交
66 67
int    tsdbPrepareCommit(STsdb *pTsdb);
int    tsdbCommit(STsdb *pTsdb);
H
more  
Hongze Cheng 已提交
68

H
refact  
Hongze Cheng 已提交
69 70 71
// STsdbCfg
int  tsdbOptionsInit(STsdbCfg *);
void tsdbOptionsClear(STsdbCfg *);
H
refact  
Hongze Cheng 已提交
72

H
refact  
Hongze Cheng 已提交
73 74 75 76
#ifdef __cplusplus
}
#endif

D
dapan1121 已提交
77
#endif /*_TD_TSDB_H_*/