Struct rocksdb::WriteBatchWithTransaction
pub struct WriteBatchWithTransaction<const TRANSACTION: bool> { /* private fields */ }
Expand description
An atomic batch of write operations.
delete_range
is not supported in Transaction
.
Making an atomic commit of several writes:
use rocksdb::{DB, Options, WriteBatchWithTransaction};
let path = "_path_for_rocksdb_storage1";
{
let db = DB::open_default(path).unwrap();
let mut batch = WriteBatchWithTransaction::<false>::default();
batch.put(b"my key", b"my value");
batch.put(b"key2", b"value2");
batch.put(b"key3", b"value3");
// delete_range is supported when use without transaction
batch.delete_range(b"key2", b"key3");
db.write(batch); // Atomically commits the batch
}
let _ = DB::destroy(&Options::default(), path);
Implementations§
§impl<const TRANSACTION: bool> WriteBatchWithTransaction<TRANSACTION>
impl<const TRANSACTION: bool> WriteBatchWithTransaction<TRANSACTION>
pub fn from_data(data: &[u8]) -> WriteBatchWithTransaction<TRANSACTION>
pub fn from_data(data: &[u8]) -> WriteBatchWithTransaction<TRANSACTION>
Construct with a reference to a byte array serialized by WriteBatch
.
pub fn len(&self) -> usize
pub fn size_in_bytes(&self) -> usize
pub fn size_in_bytes(&self) -> usize
Return WriteBatch serialized size (in bytes).
pub fn data(&self) -> &[u8] ⓘ
pub fn data(&self) -> &[u8] ⓘ
Return a reference to a byte array which represents a serialized version of the batch.
pub fn is_empty(&self) -> bool
pub fn iterate(&self, callbacks: &mut dyn WriteBatchIterator)
pub fn iterate(&self, callbacks: &mut dyn WriteBatchIterator)
Iterate the put and delete operations within this write batch. Note that
this does not return an Iterator
but instead will invoke the put()
and delete()
member functions of the provided WriteBatchIterator
trait implementation.
pub fn put<K, V>(&mut self, key: K, value: V)
pub fn put<K, V>(&mut self, key: K, value: V)
Insert a value into the database under the given key.
pub fn put_cf<K, V>(&mut self, cf: &impl AsColumnFamilyRef, key: K, value: V)
pub fn merge<K, V>(&mut self, key: K, value: V)
pub fn merge_cf<K, V>(&mut self, cf: &impl AsColumnFamilyRef, key: K, value: V)
pub fn delete<K>(&mut self, key: K)
pub fn delete<K>(&mut self, key: K)
Removes the database entry for key. Does nothing if the key was not found.
pub fn delete_cf<K>(&mut self, cf: &impl AsColumnFamilyRef, key: K)
pub fn clear(&mut self)
pub fn clear(&mut self)
Clear all updates buffered in this batch.
§impl WriteBatchWithTransaction<false>
impl WriteBatchWithTransaction<false>
pub fn delete_range<K>(&mut self, from: K, to: K)
pub fn delete_range<K>(&mut self, from: K, to: K)
Remove database entries from start key to end key.
Removes the database entries in the range [“begin_key”, “end_key”), i.e., including “begin_key” and excluding “end_key”. It is not an error if no keys exist in the range [“begin_key”, “end_key”).
pub fn delete_range_cf<K>(
&mut self,
cf: &impl AsColumnFamilyRef,
from: K,
to: K,
)
pub fn delete_range_cf<K>( &mut self, cf: &impl AsColumnFamilyRef, from: K, to: K, )
Remove database entries in column family from start key to end key.
Removes the database entries in the range [“begin_key”, “end_key”), i.e., including “begin_key” and excluding “end_key”. It is not an error if no keys exist in the range [“begin_key”, “end_key”).