table.h 3.5 KB
Newer Older
羽飞's avatar
羽飞 已提交
1 2 3 4 5 6 7 8 9 10 11
/* Copyright (c) 2021 Xie Meiyi(xiemeiyi@hust.edu.cn) and OceanBase and/or its affiliates. All rights reserved.
miniob is licensed under Mulan PSL v2.
You can use this software according to the terms and conditions of the Mulan PSL v2.
You may obtain a copy of Mulan PSL v2 at:
         http://license.coscl.org.cn/MulanPSL2
THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
See the Mulan PSL v2 for more details. */

//
12
// Created by Meiyi & Wangyunlai on 2021/5/12.
羽飞's avatar
羽飞 已提交
13 14
//

羽飞's avatar
羽飞 已提交
15
#pragma once
羽飞's avatar
羽飞 已提交
16

羽飞's avatar
羽飞 已提交
17
#include <functional>
羽飞's avatar
羽飞 已提交
18 19
#include "storage/common/table_meta.h"

W
wangyunlai.wyl 已提交
20
struct RID;
羽飞's avatar
羽飞 已提交
21
class Record;
羽飞's avatar
羽飞 已提交
22 23
class DiskBufferPool;
class RecordFileHandler;
W
wangyunlai.wyl 已提交
24
class RecordFileScanner;
羽飞's avatar
羽飞 已提交
25 26 27 28 29 30 31
class ConditionFilter;
class DefaultConditionFilter;
class Index;
class IndexScanner;
class RecordDeleter;
class Trx;

羽飞's avatar
羽飞 已提交
32
// TODO remove the routines with condition
羽飞's avatar
羽飞 已提交
33 34
class Table 
{
羽飞's avatar
羽飞 已提交
35
public:
羽飞's avatar
羽飞 已提交
36
  Table() = default;
羽飞's avatar
羽飞 已提交
37 38 39 40 41 42 43 44 45 46
  ~Table();

  /**
   * 创建一个表
   * @param path 元数据保存的文件(完整路径)
   * @param name 表名
   * @param base_dir 表数据存放的路径
   * @param attribute_count 字段个数
   * @param attributes 字段
   */
47 48 49 50 51 52
  RC create(int32_t table_id, 
            const char *path, 
            const char *name, 
            const char *base_dir, 
            int attribute_count, 
            const AttrInfo attributes[]);
羽飞's avatar
羽飞 已提交
53 54 55 56 57 58

  /**
   * 打开一个表
   * @param meta_file 保存表元数据的文件完整路径
   * @param base_dir 表所在的文件夹,表记录数据文件、索引数据文件存放位置
   */
羽飞's avatar
羽飞 已提交
59
  RC open(const char *meta_file, const char *base_dir);
60

61 62 63 64 65 66 67
  /**
   * @brief 根据给定的字段生成一个记录/行
   * @details 通常是由用户传过来的字段,按照schema信息组装成一个record。
   * @param value_num 字段的个数
   * @param values    每个字段的值
   * @param record    生成的记录数据
   */
羽飞's avatar
羽飞 已提交
68
  RC make_record(int value_num, const Value *values, Record &record);
69 70 71 72 73 74

  /**
   * @brief 在当前的表中插入一条记录
   * @details 在表文件和索引中插入关联数据。这里只管在表中插入数据,不关心事务相关操作。
   * @param record[in/out] 传入的数据包含具体的数据,插入成功会通过此字段返回RID
   */
羽飞's avatar
羽飞 已提交
75 76 77 78
  RC insert_record(Record &record);
  RC delete_record(const Record &record);
  RC visit_record(const RID &rid, bool readonly, std::function<void(Record &)> visitor);
  RC get_record(const RID &rid, Record &record);
羽飞's avatar
羽飞 已提交
79

80 81
  RC recover_insert_record(Record &record);

羽飞's avatar
羽飞 已提交
82 83
  // TODO refactor
  RC create_index(Trx *trx, const FieldMeta *field_meta, const char *index_name);
羽飞's avatar
羽飞 已提交
84

羽飞's avatar
羽飞 已提交
85
  RC get_record_scanner(RecordFileScanner &scanner, Trx *trx, bool readonly);
W
wangyunlai.wyl 已提交
86

羽飞's avatar
羽飞 已提交
87 88 89 90 91
  RecordFileHandler *record_handler() const
  {
    return record_handler_;
  }

羽飞's avatar
羽飞 已提交
92
public:
93
  int32_t table_id() const { return table_meta_.table_id(); }
羽飞's avatar
羽飞 已提交
94 95 96 97 98 99 100 101 102
  const char *name() const;

  const TableMeta &table_meta() const;

  RC sync();

private:
  RC insert_entry_of_indexes(const char *record, const RID &rid);
  RC delete_entry_of_indexes(const char *record, const RID &rid, bool error_on_not_exists);
103

羽飞's avatar
羽飞 已提交
104 105 106
private:
  RC init_record_handler(const char *base_dir);

羽飞's avatar
羽飞 已提交
107
public:
羽飞's avatar
羽飞 已提交
108
  Index *find_index(const char *index_name) const;
羽飞's avatar
羽飞 已提交
109
  Index *find_index_by_field(const char *field_name) const;
羽飞's avatar
羽飞 已提交
110 111

private:
112
  std::string base_dir_;
113
  TableMeta   table_meta_;
羽飞's avatar
羽飞 已提交
114
  DiskBufferPool *data_buffer_pool_ = nullptr;   /// 数据文件关联的buffer pool
羽飞's avatar
羽飞 已提交
115
  RecordFileHandler *record_handler_ = nullptr;  /// 记录操作
116
  std::vector<Index *> indexes_;
羽飞's avatar
羽飞 已提交
117
};