Struct yedb::Database

source ·
pub struct Database {
    pub auto_repair: bool,
    pub auto_flush: bool,
    pub write_modified_only: bool,
    pub timeout: Duration,
    pub lock_ex: bool,
    pub auto_bak: u64,
    pub skip_bak: Vec<String>,
    pub strict_schema: bool,
    /* private fields */
}

Fields§

§auto_repair: bool§auto_flush: bool§write_modified_only: bool§timeout: Duration§lock_ex: bool§auto_bak: u64§skip_bak: Vec<String>§strict_schema: bool

Implementations§

source§

impl Database

source

pub fn new() -> Self

Examples found in repository?
examples/embed.rs (line 5)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn is_open(&self) -> bool

source

pub fn set_default_fmt( &mut self, fmt: &str, checksums: bool ) -> Result<(), Error>

§Errors

Will return Err if the database is already open or the format is unknown

source

pub fn set_db_path(&mut self, path: &str) -> Result<(), Error>

§Errors

Will return Err if the database is already open

Examples found in repository?
examples/embed.rs (line 6)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn set_cache_size(&mut self, size: usize)

source

pub fn set_lock_path(&mut self, path: &str) -> Result<(), Error>

§Errors

Will return Err if the database is already open

source

pub fn open(&mut self) -> Result<ServerInfo, Error>

§Errors

Will return Err on I/O errors or if the engine is not initialized

Examples found in repository?
examples/embed.rs (line 7)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn close(&mut self) -> Result<(), Error>

§Errors

Will return errors if the database is not opened or on I/O errors

Examples found in repository?
examples/embed.rs (line 12)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn key_load_from_serialized(&mut self, data: &[Value]) -> Result<(), Error>

§Errors

Will return Err on I/O errors

source

pub fn info(&self) -> Result<DBInfo, Error>

§Errors

Will return Err if the database is not open

§Panics

Will panic on internal errors

source

pub fn server_set(&mut self, name: &str, value: Value) -> Result<(), Error>

§Errors

Will return Err on invalid property or value

source

pub fn purge(&mut self) -> Result<Vec<String>, Error>

§Errors

Will return Err on I/O errors

source

pub fn safe_purge(&mut self) -> Result<(), Error>

§Errors

Will return Err on I/O errors

source

pub fn purge_cache(&mut self) -> Result<(), Error>

§Errors

Will return Err on I/O errors

source

pub fn key_delete(&mut self, key: &str) -> Result<(), Error>

§Errors

Will return Err on I/O errors

Examples found in repository?
examples/embed.rs (line 11)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn key_delete_recursive(&mut self, key: &str) -> Result<(), Error>

§Errors

Will return Err on I/O errors

source

pub fn key_explain(&mut self, key: &str) -> Result<KeyExplained, Error>

§Errors

Will return Err if the key is not found and on I/O errors

§Panics

Will panic on internal errors

source

pub fn key_get(&mut self, key: &str) -> Result<Value, Error>

§Errors

Will return Err if the key is not found and on I/O errors

Examples found in repository?
examples/embed.rs (line 10)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn key_get_recursive( &mut self, key: &str ) -> Result<Vec<(String, Value)>, Error>

§Errors

Will return Err on I/O errors

source

pub fn key_get_field(&mut self, key: &str, field: &str) -> Result<Value, Error>

Get key field

field may contain a simple path (e.g. field/subfield/subsubfield)

§Errors

Will return Err if the key is not found, on I/O or serialization errors

source

pub fn key_set_field( &mut self, key: &str, field: &str, value: Value ) -> Result<(), Error>

Set key field

field may contain a simple path (e.g. field/subfield/subsubfield)

§Errors

Will return Err on I/O or serialization errors

§Panics

Will panic on internal serde errors

source

pub fn key_delete_field(&mut self, key: &str, field: &str) -> Result<(), Error>

Delete key field

field may contain a simple path (e.g. field/subfield/subsubfield)

§Errors

Will return Err on I/O or serialization errors

source

pub fn key_set(&mut self, key: &str, value: Value) -> Result<(), Error>

§Errors

Will return Err on I/O or serialization errors

Examples found in repository?
examples/embed.rs (line 9)
4
5
6
7
8
9
10
11
12
13
fn main() {
    let mut db = Database::new();
    db.set_db_path(&"/tmp/db1").unwrap();
    db.open().unwrap();
    let key_name = "test/key1";
    db.key_set(&key_name, Value::from(123_u8)).unwrap();
    println!("{:?}", db.key_get(&key_name));
    db.key_delete(&key_name).unwrap();
    db.close().unwrap();
}
source

pub fn key_list(&mut self, key: &str) -> Result<Vec<String>, Error>

§Errors

Will return Err on I/O errors

source

pub fn key_list_all(&mut self, key: &str) -> Result<Vec<String>, Error>

§Errors

Will return Err on I/O errors

source

pub fn key_copy(&mut self, key: &str, dst_key: &str) -> Result<(), Error>

§Errors

Will return Err if the key is not found or is unable to be copied

source

pub fn key_increment(&mut self, key: &str) -> Result<i64, Error>

§Errors

Will return Err if the key is not found, is not numeric or I/O error occured

source

pub fn key_decrement(&mut self, key: &str) -> Result<i64, Error>

§Errors

Will return Err if the key is not found, is not numeric or I/O error occured

source

pub fn key_rename(&mut self, key: &str, dst_key: &str) -> Result<(), Error>

§Errors

Will return Err if the key is not found or is unable to be renamed

source

pub fn check(&mut self) -> Result<Vec<String>, Error>

§Errors

Will return Err on I/O errors

§Panics

Will panic on internal path errors

source

pub fn repair(&mut self) -> Result<Vec<(String, bool)>, Error>

§Errors

Will return Err on I/O errors

§Panics

Will panic on internal path errors

source

pub fn key_dump(&mut self, key: &str) -> Result<Vec<(String, Value)>, Error>

§Errors

Will return Err if keys are unable to be read

source

pub fn key_load(&mut self, data: Vec<(String, Value)>) -> Result<(), Error>

§Errors

Will return Err if key is not found or unable to be read

Trait Implementations§

source§

impl Default for Database

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl Drop for Database

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

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.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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>,

§

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>,

§

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.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more