redb

Struct MultimapTable

Source
pub struct MultimapTable<'txn, K: Key + 'static, V: Key + 'static> { /* private fields */ }
Expand description

A multimap table

Multimap tables may have multiple values associated with each key

Implementations§

Source§

impl<'txn, K: Key + 'static, V: Key + 'static> MultimapTable<'txn, K, V>

Source

pub fn insert<'k, 'v>( &mut self, key: impl Borrow<K::SelfType<'k>>, value: impl Borrow<V::SelfType<'v>>, ) -> Result<bool>

Add the given value to the mapping of the key

Returns true if the key-value pair was present

Source

pub fn remove<'k, 'v>( &mut self, key: impl Borrow<K::SelfType<'k>>, value: impl Borrow<V::SelfType<'v>>, ) -> Result<bool>

Removes the given key-value pair

Returns true if the key-value pair was present

Source

pub fn remove_all<'a>( &mut self, key: impl Borrow<K::SelfType<'a>>, ) -> Result<MultimapValue<'_, V>>

Removes all values for the given key

Returns an iterator over the removed values. Values are in ascending order.

Trait Implementations§

Source§

impl<'txn, K: Key + 'static, V: Key + 'static> Drop for MultimapTable<'txn, K, V>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<K: Key + 'static, V: Key + 'static> MultimapTableHandle for MultimapTable<'_, K, V>

Source§

fn name(&self) -> &str

Source§

impl<'txn, K: Key + 'static, V: Key + 'static> ReadableMultimapTable<K, V> for MultimapTable<'txn, K, V>

Source§

fn get<'a>( &self, key: impl Borrow<K::SelfType<'a>>, ) -> Result<MultimapValue<'_, V>>

Returns an iterator over all values for the given key. Values are in ascending order.

Source§

fn range<'a, KR>( &self, range: impl RangeBounds<KR> + 'a, ) -> Result<MultimapRange<'_, K, V>>
where KR: Borrow<K::SelfType<'a>> + 'a,

Returns a double-ended iterator over a range of elements in the table

Source§

fn iter(&self) -> Result<MultimapRange<'_, K, V>>

Returns an double-ended iterator over all elements in the table. Values are in ascending order.
Source§

impl<'txn, K: Key + 'static, V: Key + 'static> ReadableTableMetadata for MultimapTable<'txn, K, V>

Source§

fn len(&self) -> Result<u64>

Returns the number of key-value pairs in the table

Source§

fn stats(&self) -> Result<TableStats>

Retrieves information about storage usage for the table
Source§

fn is_empty(&self) -> Result<bool>

Returns true if the table is empty

Auto Trait Implementations§

§

impl<'txn, K, V> Freeze for MultimapTable<'txn, K, V>

§

impl<'txn, K, V> !RefUnwindSafe for MultimapTable<'txn, K, V>

§

impl<'txn, K, V> Send for MultimapTable<'txn, K, V>
where V: Send + Sync, K: Send,

§

impl<'txn, K, V> Sync for MultimapTable<'txn, K, V>
where V: Sync, K: Sync,

§

impl<'txn, K, V> Unpin for MultimapTable<'txn, K, V>
where V: Unpin, K: Unpin,

§

impl<'txn, K, V> !UnwindSafe for MultimapTable<'txn, K, V>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 160 bytes