Quickstart
The following is the quickstart guide for the agdb emebedded/application database.
Looking for server client guide instead?
Install Rust toolchain
From the official source.
Create an applicaiton
First we initialize an application called agdb_app
with cargo:
mkdir agdb_app
cd agdb_app
cargo init
Add dependencies
cargo add agdb
Create the database
In main.rs
we create a memory mapped database:
main.rs
use agdb::QueryError;
fn main() -> Result<(), QueryError> {
let mut db = Db::new("agdb_app.agdb")?;
Ok(())
}
The namesake file “agdb_app.agdb” will be created in your working directory. The .agdb extension is conventional.
Run queries
We run our first query against the database inserting a node with alias “users”:
db.exec_mut(QueryBuilder::insert()
.nodes()
.aliases("users")
.query())?;
We then insert additional nodes representing some users and connect them with the “users” node:
// We derive from agdb::UserValue
// so we can use the type in the db.
#[derive(Debug, UserValue)]
struct User {
db_id: Option<DbId>, // The db_id member is optional but
// it allows insert your user type
// directly into the database.
username: String,
age: u64,
}
let users = vec![User { db_id: None, username: "Alice".to_string(), age: 40 },
User { db_id: None, username: "Bob".to_string(), age: 30 },
User { db_id: None, username: "John".to_string(), age: 20 }];
let db_users = db.exec_mut(QueryBuilder::insert()
.nodes()
.values(&users) // We can pass users directly as
// query parameter thanks to the
// implementation of the agdb::DbUserValue
// trait via #[derive(UserValue)].
.query())?;
db.exec_mut(
QueryBuilder::insert()
.edges()
.from("users")
.to(&db_users) // We can feed result of a previous
// query directly to the next one.
.query(),
)?;
💡
We could also run all the queries as a single transaction with
transaction()
/ transaction_mut()
instead of exec variants that operate
on a single query each time.
Find a user in the database matching some conditions
// We combine search & select into a single query like so:
let users: Vec<User> = db
.exec(
QueryBuilder::select()
.elements::<User>() // Select only relevant properties for the User struct.
.search()
.from("users") // Start the search from the "users" node.
.where_()
.key("age") // Examine "age" property.
.value(LessThan(40.into())) // Include it in the search result if the value
// is less than 40.
.query(),
)?
.try_into()?; // Convert the result into a list of User objects.
println!("{:?}", users);
// We can print the users thanks to #[derive(Debug)]. The result should be something like:
// Vec [User { db_id: Some(DbId(3)), username: "John", age: 20 }, User { db_id: Some(DbId(3)), username: "Bob", age: 30 }]
Run the program
cargo run