Crates.io | b-table |
lib.rs | b-table |
version | 0.3.0 |
source | src |
created_at | 2023-07-24 18:25:53.729113 |
updated_at | 2024-08-13 23:48:10.973828 |
description | A persistent database table based on b-tree |
homepage | |
repository | https://github.com/haydnv/b-table |
max_upload_size | |
id | 924845 |
size | 121,812 |
A persistent database table based on b-tree, with support for multiple indices.
Example usage:
use b_table::{Collator, Schema, TableLock};
enum ColumnValue {
U64(u64),
Str(String),
}
# ...
// note: b-table provides a Schema trait but not a struct which implements it
let schema = Schema::new(
["zero", "one", "two", "value"],
[
("index_one", ["one", "zero", "two"]),
("index_two", ["two", "zero", "one"]),
]
);
let key: Vec<ColumnValue> = vec![0.into(), 0.into(), 0.into()];
let value: Vec<ColumnValue> = vec!["value".into()];
let table = TableLock::create(schema, Collator::new(), dir)?;
{
let mut table = table.write().await; // or table.try_write()?
table.upsert(key.clone(), value.clone()).await?;
assert_eq!(table.get_value(key.clone())).await?, Ok(Some(value.clone()));
}
let mut expected_row = key;
expected_row.extend(value);
{
let order = &["two", "one", "zero"];
let range = [("one", 0)].into_iter().collect();
let table = table.read().await; // or table.try_read()?
let mut rows = table.rows(order, range, Some(&["value"]))?;
assert_eq!(rows.try_next().await, Ok(Some(expected_row)));
}