pub trait KeyValueDB: Sync + Send + MallocSizeOf {
fn get(&self, col: u32, key: &[u8]) -> Result<Option<Vec<u8, Global>>, Error>;
fn get_by_prefix(&self, col: u32, prefix: &[u8]) -> Option<Box<[u8], Global>>;
fn write(&self, transaction: DBTransaction) -> Result<(), Error>;
fn iter<'a>(
&'a self,
col: u32
) -> Box<dyn Iterator<Item = (Box<[u8], Global>, Box<[u8], Global>)> + 'a, Global>;
fn iter_with_prefix<'a>(
&'a self,
col: u32,
prefix: &'a [u8]
) -> Box<dyn Iterator<Item = (Box<[u8], Global>, Box<[u8], Global>)> + 'a, Global>;
fn restore(&self, new_db: &str) -> Result<(), Error>;
fn transaction(&self) -> DBTransaction { ... }
fn io_stats(&self, _kind: Kind) -> IoStats { ... }
fn has_key(&self, col: u32, key: &[u8]) -> Result<bool, Error> { ... }
fn has_prefix(&self, col: u32, prefix: &[u8]) -> bool { ... }
}
Expand description
Generic key-value database.
The KeyValueDB
deals with “column families”, which can be thought of as distinct
stores within a database. Keys written in one column family will not be accessible from
any other. The number of column families must be specified at initialization, with a
differing interface for each database.
The API laid out here, along with the Sync
bound implies interior synchronization for
implementation.
Required Methods§
sourcefn get(&self, col: u32, key: &[u8]) -> Result<Option<Vec<u8, Global>>, Error>
fn get(&self, col: u32, key: &[u8]) -> Result<Option<Vec<u8, Global>>, Error>
Get a value by key.
sourcefn get_by_prefix(&self, col: u32, prefix: &[u8]) -> Option<Box<[u8], Global>>
fn get_by_prefix(&self, col: u32, prefix: &[u8]) -> Option<Box<[u8], Global>>
Get the first value matching the given prefix.
sourcefn write(&self, transaction: DBTransaction) -> Result<(), Error>
fn write(&self, transaction: DBTransaction) -> Result<(), Error>
Write a transaction of changes to the backing store.
sourcefn iter<'a>(
&'a self,
col: u32
) -> Box<dyn Iterator<Item = (Box<[u8], Global>, Box<[u8], Global>)> + 'a, Global>
fn iter<'a>(
&'a self,
col: u32
) -> Box<dyn Iterator<Item = (Box<[u8], Global>, Box<[u8], Global>)> + 'a, Global>
Iterate over the data for a given column.
Provided Methods§
sourcefn transaction(&self) -> DBTransaction
fn transaction(&self) -> DBTransaction
Helper to create a new transaction.
sourcefn io_stats(&self, _kind: Kind) -> IoStats
fn io_stats(&self, _kind: Kind) -> IoStats
Query statistics.
Not all kvdb implementations are able or expected to implement this, so by default, empty statistics is returned. Also, not all kvdb implementation can return every statistic or configured to do so (some statistics gathering may impede the performance and might be off by default).
sourcefn has_key(&self, col: u32, key: &[u8]) -> Result<bool, Error>
fn has_key(&self, col: u32, key: &[u8]) -> Result<bool, Error>
Check for the existence of a value by key.
sourcefn has_prefix(&self, col: u32, prefix: &[u8]) -> bool
fn has_prefix(&self, col: u32, prefix: &[u8]) -> bool
Check for the existence of a value by prefix.