Использование rockdb::Iterator и семейства столбцов не работает

У меня есть следующий фрагмент кода:

rocksdb::DBWithTTL* db = ...
rocksdb::WriteOptions writeOptions;
rocksdb::ColumnFamilyHandle cfHandle = ...

std::string keyPrefix = "prefix";
std::string key = keyPrefix + "_key";
std::string value = "value";
rocksdb::Status s = db->Put(writeOptions, cfHandle, key, value);

rocksdb::ReadOptions readOptions;
readOptions.prefix_same_as_start;
readOptions.snapshot = db->GetSnapshot();
rocksdb::Iterator* iterator = db->NewIterator(readOptions);

rocksdb::Sliced start = rocksdb::Slice(keyPrefix);
for (iterator->Seek(start); iterator->Valid(); iterator->Next()) {
  printf("hello");
}

printf никогда не попадает.

Однако, если я изменю строку Put на:

rocksdb::Status s = db->Put(writeOptions, key, value);

Это означает, что, удалив column family handle, я напечатаю строку нормально.

Я предполагаю, что API-интерфейс итератора должен учитывать семейство столбцов, но я не смог найти никакой документации.


person Mugen    schedule 17.08.2016    source источник


Ответы (1)


Действительно, отсутствующий вызов API был:

rocksdb::Iterator* iterator = db->NewIterator(readOptions, cfHandle);
person Mugen    schedule 17.08.2016