|
# ifndef FIELD_DB_H
|
|
# define FIELD_DB_H
|
|
|
|
#include "port/port_stdcxx.h"
|
|
#include "db/db_impl.h"
|
|
#include <deque>
|
|
#include <map>
|
|
#include <set>
|
|
#include <string>
|
|
#include "leveldb/db.h"
|
|
#include "leveldb/options.h"
|
|
#include "leveldb/slice.h"
|
|
#include "leveldb/status.h"
|
|
|
|
#include "fielddb/request.h"
|
|
|
|
namespace fielddb {
|
|
using namespace leveldb;
|
|
class FieldDB : DB {
|
|
public:
|
|
//用的时候必须FieldDB *db = new FieldDB()再open,不能像之前一样DB *db
|
|
FieldDB() : indexDB_(nullptr), kvDB_(nullptr), metaDB_(nullptr) {};
|
|
/*lab1的要求,作为db派生类要实现的虚函数*/
|
|
Status Put(const WriteOptions &options, const Slice &key, const Slice &value) override;
|
|
Status PutFields(const WriteOptions &, const Slice &key, const FieldArray &fields) override;
|
|
Status Delete(const WriteOptions &options, const Slice &key) override;
|
|
Status Write(const WriteOptions &options, WriteBatch *updates) override;
|
|
Status Get(const ReadOptions &options, const Slice &key, std::string *value) override;
|
|
Status GetFields(const ReadOptions &options, const Slice &key, FieldArray *fields) override;
|
|
std::vector<std::string> FindKeysByField(Field &field) override;
|
|
Iterator * NewIterator(const ReadOptions &options) override;
|
|
const Snapshot * GetSnapshot() override;
|
|
void ReleaseSnapshot(const Snapshot *snapshot) override;
|
|
bool GetProperty(const Slice &property, std::string *value) override;
|
|
void GetApproximateSizes(const Range *range, int n, uint64_t *sizes) override;
|
|
void CompactRange(const Slice *begin, const Slice *end) override;
|
|
/*与索引相关*/
|
|
Status CreateIndexOnField(const std::string& field_name);
|
|
Status DeleteIndex(const std::string &field_name);
|
|
std::vector<std::string> QueryByIndex(const Field &field, Status *s);
|
|
|
|
static Status OpenFieldDB(const Options& options,const std::string& name,FieldDB** dbptr);
|
|
|
|
private:
|
|
//根据metaDB的内容进行恢复
|
|
Status Recover();
|
|
|
|
private:
|
|
std::string dbname_;
|
|
|
|
leveldb::DB *metaDB_;
|
|
leveldb::DB *indexDB_;
|
|
leveldb::DB *kvDB_;
|
|
|
|
enum IndexStatus{
|
|
Creating,
|
|
Deleting,
|
|
Exist
|
|
};
|
|
std::map<std::string, int> index_;
|
|
leveldb::port::Mutex mutex_; // mutex for taskqueue
|
|
std::deque<Request *> taskqueue_;
|
|
|
|
std::vector<std::pair<std::string, std::string>> FindKeysAndValByFieldName (
|
|
const std::string &fieldName);
|
|
};
|
|
} // end of namespace
|
|
# endif
|