DB

Struct DB 

Source
pub struct DB(/* private fields */);
Expand description

Database

Implementations§

Source§

impl<'a> DB

Source

pub fn get_meta(file: &mut File) -> Result<Meta, String>

Returns meta info for given path

Source

pub fn page_size(&self) -> usize

Returns database’s defined page size

Source

pub fn remove(self) -> Result<(), Error>

Closes database and removes it’s data file

Source

pub fn path(&self) -> &Path

Source

pub fn read_only(&self) -> bool

Source

pub fn opened(&self) -> bool

Source

pub fn begin_tx(&'a self) -> Result<TxGuard<'a>, Error>

Starts a new transaction. Multiple read-only transactions can be used concurrently but only one write transaction can be used at a time.

Transactions should not be dependent on one another.

If a long running read transaction (for example, a snapshot transaction) is needed, you might want to set DBBuilder.initial_mmap_size to a large enough value to avoid potential blocking of write transaction.

Source

pub fn begin_rw_tx(&'a mut self) -> Result<RWTxGuard<'a>, Error>

Starts a new writable transaction. Multiple read-only transactions can be used concurrently but only one write transaction can be used at a time.

Transactions should not be dependent on one another.

If a long running read transaction (for example, a snapshot transaction) is needed, you might want to set DBBuilder.initial_mmap_size to a large enough value to avoid potential blocking of write transaction.

Source

pub fn update<'b>( &mut self, handler: Box<dyn FnMut(&mut Tx) -> Result<(), String> + 'b>, ) -> Result<(), Error>

shorthand for db.begin_rw_tx with additional guarantee for panic safery

Source

pub fn view<'b>( &self, handler: Box<dyn Fn(&Tx) -> Result<(), String> + 'b>, ) -> Result<(), Error>

shorthand for db.begin_tx with additional guarantee for panic safery

Source

pub fn batch( &mut self, handler: Box<dyn Fn(&mut Tx) -> Result<(), String> + Send>, ) -> Result<(), Error>

Calls fn as part of a batch. It behaves similar to Update, except:

  1. concurrent batch calls can be combined into a single transaction.

  2. the function passed to batch may be called multiple times, regardless of whether it returns error or not.

This means that Batch function side effects must be idempotent and take permanent effect only after a successful return is seen in caller.

The maximum batch size and delay can be adjusted with DBBuilder.batch_size and DBBuilder.batch_delay, respectively.

Batch is only useful when there are multiple threads calling it. While calling it multiple times from single thread just blocks thread for each single batch call

Source

pub fn stats(&self) -> Stats

Source

pub fn info(&self) -> Info

Source

pub fn meta(&self) -> Result<Meta, Error>

Trait Implementations§

Source§

impl Clone for DB

Source§

fn clone(&self) -> DB

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Drop for DB

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl Freeze for DB

§

impl !RefUnwindSafe for DB

§

impl Send for DB

§

impl Sync for DB

§

impl Unpin for DB

§

impl !UnwindSafe for DB

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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.