一个基于sqlx的极简orm,本项目将sql代码以derive属性方式和结构体进行关联,并自动生成相关CRUD相关API,可根据需要实现任意复杂度的数据获取。
本项目开发主要原因:
因此,是否可以将数据查询的sql和rust结合,由程序员自行控制sql的表现,这样在rust的高性能助力下,我们可以写成性能超级赞的数据库应用。
根据你的数据库类型选择不同特性,缺省为mysql
修改Cargo.toml,增加
``` [dependencies] async-trait = "^0.1" tinyormmacro_derive="^0.2"
[dependencies.tinyormcore] version = "^0.2" features = [ "mysql", ]
```
``` //! 数据库模型的测试 use sqlx::mysql::MySqlPoolOptions; use sqlx::Row; use tinyormcore::prelude::*;
use super::*;
pub struct UserType {
/// 类型编号
pub id: Option
pub struct TestUser {
/// 类型编号
pub id: Option
impl TestUser {
/// 完整创建器
///
/// # 参数说明
///
/// * id 编号
/// * name 姓名
/// * mobilephone 手机
/// * password 密码
/// * usertype 用户类型
/// * org 对应机构
pub fn new(
id: u32,
name: &str,
mobilephone: &str,
password: &str,
usertype: UserType,
) -> Self {
Self {
id: Some(id),
name: name.into(),
mobilephone: mobilephone.into(),
password: password.into(),
usertype,
}
}
}
/// 实现数据获取接口
/// tinyorm 会自动实现各种数据获取和更新等方法,其中:
/// TestUser::ormfilterwithsql等orm开头的方法,会调用TestUser::ormrowmap进行数据转换
/// TestUser::dbfetchallrow等db开头的方法,直接返回sqlx:Row
impl TinyOrmData for TestUser {
/// 将sql返回数据映射为TestUser
fn ormrowmap(row: TinyOrmSqlRow) -> Self {
TestUser::new(
row.get::
async fn getpool() -> Result
/// 测试SQL生成 /// 也可以使用TestUser::DBMETA.buildselect_sql等方法生成个性化sql
fn testuser() { println!("user sql : \n{}", TestUser::DBMETA.select_sql); }
/// 测试数据获取
fn testdbquery() { tokio::runtime::Builder::newcurrentthread() .enableall() .build() .unwrap() .blockon(async { let pool = getpool().await.unwrap(); let data = TestUser::ormget_all(&pool).await.unwrap(); dbg!(data); }); }
/// 测试根据id获取用户
fn testormgetbyid() { tokio::runtime::Builder::newcurrentthread() .enableall() .build() .unwrap() .blockon(async { let pool = getpool().await.unwrap(); let user = TestUser::ormgetbyid(&pool, 1).await.unwrap(); dbg!(user); }); }
/// 测试是否存在
fn testormexists() { tokio::runtime::Builder::newcurrentthread() .enableall() .build() .unwrap() .blockon(async { let pool = getpool().await.unwrap(); let isexist = TestUser::ormexists(&pool, 1).await.unwrap(); dbg!(isexist); }); }
/// 测试删除
fn testormdelete() { tokio::runtime::Builder::newcurrentthread() .enableall() .build() .unwrap() .blockon(async { let pool = getpool().await.unwrap(); TestUser::ormdelete(&pool, 6).await.unwrap();
});
}
/// 测试filter
fn testdbfilter() { tokio::runtime::Builder::newcurrentthread() .enableall() .build() .unwrap() .blockon(async { let pool = getpool().await.unwrap(); let sql = TestUser::DBMETA.buildselectsql("name like ? "); println!("{sql}"); let key = String::from("%黄%"); let data = TestUser::ormfilterwith_sql(&pool, &sql, &key).await.unwrap(); dbg!(data); }); } ```