feat: seaorm

This commit is contained in:
Ahmet Kaan GÜMÜŞ 2024-12-02 23:56:43 +03:00
parent 36c72cee4a
commit 40149b372d
20 changed files with 236 additions and 87 deletions

View file

@ -1,29 +1 @@
use crate::feature::user::User;
use super::{SurrealCountReturn, SurrealUserReturn, DB};
pub async fn create_user(user:User) -> SurrealUserReturn {
DB.create("user").content(user).await
}
pub async fn read_user(email: &String) -> SurrealUserReturn{
DB.select(("user", email)).await
}
pub async fn update_user(target_user_email: &String, user: User) -> SurrealUserReturn{
DB.update(("user", target_user_email)).content(user).await
}
pub async fn delete_user(email: &String) -> SurrealUserReturn {
DB.delete(("user", email)).await
}
pub async fn count_users() -> SurrealCountReturn{
DB.query("SELECT count() FROM user GROUP BY count;").await?.take("count")
}
pub async fn count_male_users() -> SurrealCountReturn{
DB.query("SELECT count() FROM user WHERE gender = true GROUP BY count;").await?.take("count")
}
pub async fn count_female_users() -> SurrealCountReturn{
DB.query("SELECT count() FROM user WHERE gender = false GROUP BY count;").await?.take("count")
}