Crates.io | surrealdb-extras |
lib.rs | surrealdb-extras |
version | 2.0.7 |
source | src |
created_at | 2024-01-30 11:16:57.838046 |
updated_at | 2024-10-18 17:15:00.858836 |
description | Provides additional functionality for working with SurrealDB |
homepage | |
repository | https://github.com/frederik-uni/surrealdb-extras |
max_upload_size | |
id | 1120124 |
size | 38,998 |
A simple library that establishes a connection and sets/creates the namespace&db and sets the types of the attributes
pub async fn establish(path: PathBuf) -> surrealdb::Result<Surreal<Db>> {
let conn = Surreal::new::<SpeeDb>((path.join("db"), Config::default().strict()));
surrealdb_extras::use_ns_db(conn, "test", "test", vec![Test::register]).await
}
#[derive(surrealdb_extras::SurrealTableEntry, Deserialize, Serialize, Clone, Default)]
#[db("test_table")]
#[sql(["DEFINE EVENT test_table_updated ON TABLE test_table WHEN $event = \"UPDATE\" AND $before.updated == $after.updated THEN (UPDATE $after.id SET updated = time::now() );"])]
struct Test {
random_number: i32,
/// renamed field
#[opt(rename = "new_name")]
#[serde(rename = "new_name")]
data: String,
/// overwrites the detected db type
#[opt(db_type = "string")]
data: CustomStructWithSerialize,
/// will be excluded in get_or_insert check
#[opt(exclude = true)]
updated: Datetime
}
pub async fn demo() {
let conn = establish(PathBuf::new()).await.unwrap();
let test = Test::default();
// creates new item with custom id and return self
let _: Option<Test> = test
.clone()
.insert(&conn, Some(sql::Id::rand()))
.await
.unwrap();
// creates new item with random id and return record
let v: surrealdb_extras::Record = test.add(&conn).await.unwrap().unwrap();
// delete record
let v: Option<surrealdb_extras::Record> = v.delete(&conn).await.unwrap();
}
the functions in RecordIdType, RecordData, Record are from RecordIdFunc
use_ns_db
impl SurrealTableInfo
(use #[derive(SurrealTable, Serialize, Deserialize)]
)impl SurrealSelectInfo
(use #[derive(SurrealSelect, Deserialize)]
or #[derive(SurrealTable, Serialize, Deserialize)]
)Record
RecordData
RecordIdFunc
(within structs)RecordIdType
(within structs)impl SurrealTableInfo
(use #[derive(SurrealTable, Serialize, Deserialize)]
)
RecordIdFunc
(within structs)
RecordIdType
(within structs)
ThingArray