|
|
|
// Copyright (c) 2011-present, Facebook, Inc. All rights reserved.
|
|
|
|
// This source code is licensed under both the GPLv2 (found in the
|
|
|
|
// COPYING file in the root directory) and Apache 2.0 License
|
|
|
|
// (found in the LICENSE.Apache file in the root directory).
|
|
|
|
#include <cstdio>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "rocksdb/db.h"
|
|
|
|
#include "rocksdb/options.h"
|
|
|
|
#include "rocksdb/slice.h"
|
|
|
|
|
|
|
|
#if defined(OS_WIN)
|
|
|
|
std::string kDBPath = "C:\\Windows\\TEMP\\rocksdb_column_families_example";
|
|
|
|
#else
|
|
|
|
std::string kDBPath = "/tmp/rocksdb_column_families_example";
|
|
|
|
#endif
|
|
|
|
|
|
|
|
using ROCKSDB_NAMESPACE::ColumnFamilyDescriptor;
|
|
|
|
using ROCKSDB_NAMESPACE::ColumnFamilyHandle;
|
|
|
|
using ROCKSDB_NAMESPACE::ColumnFamilyOptions;
|
|
|
|
using ROCKSDB_NAMESPACE::DB;
|
|
|
|
using ROCKSDB_NAMESPACE::DBOptions;
|
|
|
|
using ROCKSDB_NAMESPACE::Options;
|
|
|
|
using ROCKSDB_NAMESPACE::ReadOptions;
|
|
|
|
using ROCKSDB_NAMESPACE::Slice;
|
|
|
|
using ROCKSDB_NAMESPACE::Status;
|
|
|
|
using ROCKSDB_NAMESPACE::WriteBatch;
|
|
|
|
using ROCKSDB_NAMESPACE::WriteOptions;
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
// open DB
|
|
|
|
Options options;
|
|
|
|
options.create_if_missing = true;
|
|
|
|
DB* db;
|
|
|
|
Status s = DB::Open(options, kDBPath, &db);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// create column family
|
|
|
|
ColumnFamilyHandle* cf;
|
|
|
|
s = db->CreateColumnFamily(ColumnFamilyOptions(), "new_cf", &cf);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// close DB
|
|
|
|
s = db->DestroyColumnFamilyHandle(cf);
|
|
|
|
assert(s.ok());
|
|
|
|
delete db;
|
|
|
|
|
|
|
|
// open DB with two column families
|
|
|
|
std::vector<ColumnFamilyDescriptor> column_families;
|
|
|
|
// have to open default column family
|
|
|
|
column_families.push_back(ColumnFamilyDescriptor(
|
|
|
|
ROCKSDB_NAMESPACE::kDefaultColumnFamilyName, ColumnFamilyOptions()));
|
|
|
|
// open the new one, too
|
|
|
|
column_families.push_back(
|
|
|
|
ColumnFamilyDescriptor("new_cf", ColumnFamilyOptions()));
|
|
|
|
std::vector<ColumnFamilyHandle*> handles;
|
|
|
|
s = DB::Open(DBOptions(), kDBPath, column_families, &handles, &db);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// put and get from non-default column family
|
|
|
|
s = db->Put(WriteOptions(), handles[1], Slice("key"), Slice("value"));
|
|
|
|
assert(s.ok());
|
|
|
|
std::string value;
|
|
|
|
s = db->Get(ReadOptions(), handles[1], Slice("key"), &value);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// atomic write
|
|
|
|
WriteBatch batch;
|
|
|
|
batch.Put(handles[0], Slice("key2"), Slice("value2"));
|
|
|
|
batch.Put(handles[1], Slice("key3"), Slice("value3"));
|
|
|
|
batch.Delete(handles[0], Slice("key"));
|
|
|
|
s = db->Write(WriteOptions(), &batch);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// drop column family
|
|
|
|
s = db->DropColumnFamily(handles[1]);
|
|
|
|
assert(s.ok());
|
|
|
|
|
|
|
|
// close db
|
|
|
|
for (auto handle : handles) {
|
|
|
|
s = db->DestroyColumnFamilyHandle(handle);
|
|
|
|
assert(s.ok());
|
|
|
|
}
|
|
|
|
delete db;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|