Document SingleDelete

Summary: Docuemented what is currently supported by SingleDelete based on its current implementation.

Test Plan: n/a

Reviewers: sdong, kradhakrishnan, yhchiang, rven

Reviewed By: rven

Subscribers: dhruba, leveldb

Differential Revision: https://reviews.facebook.net/D50205
main
agiardullo 9 years ago
parent e89e5b253c
commit fe789c5f2b
  1. 12
      include/rocksdb/db.h
  2. 3
      include/rocksdb/write_batch.h

@ -189,6 +189,18 @@ class DB {
// Remove the database entry for "key". Requires that the key exists // Remove the database entry for "key". Requires that the key exists
// and was not overwritten. Returns OK on success, and a non-OK status // and was not overwritten. Returns OK on success, and a non-OK status
// on error. It is not an error if "key" did not exist in the database. // on error. It is not an error if "key" did not exist in the database.
//
// If a key is overwritten (by calling Put() multiple times), then the result
// of calling SingleDelete() on this key is undefined. SingleDelete() only
// behaves correctly if there has been only one Put() for this key since the
// previous call to SingleDelete() for this key.
//
// This feature is currently an experimental performance optimization
// for a very specific workload. It is up to the caller to ensure that
// SingleDelete is only used for a key that is not deleted using Delete() or
// written using Merge(). Mixing SingleDelete operations with Deletes and
// Merges can result in undefined behavior.
//
// Note: consider setting options.sync = true. // Note: consider setting options.sync = true.
virtual Status SingleDelete(const WriteOptions& options, virtual Status SingleDelete(const WriteOptions& options,
ColumnFamilyHandle* column_family, ColumnFamilyHandle* column_family,

@ -71,8 +71,7 @@ class WriteBatch : public WriteBatchBase {
void Delete(const SliceParts& key) override { Delete(nullptr, key); } void Delete(const SliceParts& key) override { Delete(nullptr, key); }
using WriteBatchBase::SingleDelete; using WriteBatchBase::SingleDelete;
// If the database contains a mapping for "key", erase it. Expects that the // WriteBatch implementation of DB::SingleDelete(). See db.h.
// key was not overwritten. Else do nothing.
void SingleDelete(ColumnFamilyHandle* column_family, void SingleDelete(ColumnFamilyHandle* column_family,
const Slice& key) override; const Slice& key) override;
void SingleDelete(const Slice& key) override { SingleDelete(nullptr, key); } void SingleDelete(const Slice& key) override { SingleDelete(nullptr, key); }

Loading…
Cancel
Save