pub unsafe trait DatabaseRo<T: Table> {
// Required methods
fn get(&self, key: &T::Key) -> DbResult<T::Value>;
fn len(&self) -> DbResult<u64>;
fn first(&self) -> DbResult<(T::Key, T::Value)>;
fn last(&self) -> DbResult<(T::Key, T::Value)>;
fn is_empty(&self) -> DbResult<bool>;
// Provided method
fn contains(&self, key: &T::Key) -> DbResult<bool> { ... }
}
Expand description
Database (key-value store) read abstraction.
This is a read-only database table,
write operations are defined in DatabaseRw
.
§Safety
The table type that implements this MUST be Send
.
However if the table holds a reference to a transaction:
- only the transaction only has to be
Send
- the table cannot implement
Send
For example:
heed
’s transactions are Send
but HeedTableRo
contains a &
to the transaction, as such, if Send
were implemented on HeedTableRo
then 1 transaction could be used to open multiple tables, then sent to
other threads - this would be a soundness hole against HeedTableRo
.
&T
is only Send
if T: Sync
.
heed::RoTxn: !Sync
, therefore our table
holding &heed::RoTxn
must NOT be Send
.
Required Methods§
Sourcefn get(&self, key: &T::Key) -> DbResult<T::Value>
fn get(&self, key: &T::Key) -> DbResult<T::Value>
Get the value corresponding to a key.
§Errors
This will return crate::RuntimeError::KeyNotFound
if:
- Input does not exist OR
- Database is empty
Sourcefn len(&self) -> DbResult<u64>
fn len(&self) -> DbResult<u64>
Returns the number of (key, value)
pairs in the database.
§Errors
This will never return RuntimeError::KeyNotFound
.
Sourcefn first(&self) -> DbResult<(T::Key, T::Value)>
fn first(&self) -> DbResult<(T::Key, T::Value)>
Returns the first (key, value)
pair in the database.
§Errors
This will return crate::RuntimeError::KeyNotFound
if:
- Input does not exist OR
- Database is empty