它会删除密钥的最新版本,并且密钥的旧版本是否会恢复正常尚未定义。
基本用法
单一删除是一个新的数据库操作。与传统的 Delete() 操作相比,当两者在压缩中排列时,删除条目与值一起删除。因此,与 method类似,删除密钥的数据库条目,但具有密钥存在且未被覆盖的先决条件。成功时返回“正常”,出错时返回“非正常”状态。如果数据库中不存在键,则不会出错。如果某个键被覆盖(通过多次调用),则调用此键的结果是不确定的。 仅当自上次调用此密钥以来只有一个密钥时,才行为正确。以下代码演示如何使用:Delete()SingleDelete()Put()SingleDelete()SingleDelete()Put()SingleDelete()SingleDelete
std::string value;
rocksdb::Status s;
db->Put(rocksdb::WriteOptions(), "foo", "bar1");
db->SingleDelete(rocksdb::WriteOptions(), "foo");
s = db->Get(rocksdb::ReadOptions(), "foo", &value); // s.IsNotFound()==true
db->Put(rocksdb::WriteOptions(), "foo", "bar2");
db->Put(rocksdb::WriteOptions(), "foo", "bar3");
db->SingleDelete(rocksdb::ReadOptions(), "foo", &value); // Undefined result
SingleDeleteAPI 在 中也可用。实际上,是通过在此批处理中创建只有一个操作来实现的。以下代码片段显示了 的基本用法:WriteBatchDB::SingleDelete()WriteBatchSingleDeleteWriteBatch::SingleDelete()
rocksdb::WriteBatch batch;
batch.Put(key1, value);
batch.SingleDelete(key1);
s = db->Write(rocksdb::WriteOptions(), &batch);