#toql #sql #expr #orm #macro #query #field

toql_sql_expr_macro

提供Toql的sql表达式宏的库

2个不稳定版本

0.4.0 2021年12月4日
0.3.0 2021年10月20日

#11 in #toql


3个crate中使用了(通过toql

MIT/Apache

14KB
235

Toql - 一款友好且高效的ORM

Tests Current Crates.io Version

入门指南 | API文档

Toql是一个异步数据库ORM,具有以下特性:

  • Rust结构体与数据库表之间的转换。
  • 可以加载和修改嵌套结构体。
  • 独特的简单查询语言,适合Web客户端。
  • 表别名从长且易读到短且快速。
  • 防止SQL注入的准备语句。
  • 支持原始SQL,以获得完整的数据库功能。
  • 支持基于角色的访问。
  • 通过用户定义的参数、查询函数、字段处理器等高度可定制。
  • 查询、字段和路径名的编译时安全性。
  • 没有不安全的Rust代码。
  • 在实际场景中进行了测试。

它目前只支持MySQL。更多数据库支持正在路上,敬请期待 :)

安装

将以下内容添加到您的Cargo.toml

[dependencies]
toql = {version = "0.4", features = ["serde"]}
toql_mysql_async = "0.4"

外观和感觉

推导您的结构体

#[derive(Toql)]
#[toql(auto_key)]
struct Todo {
    #[toql(key)]
    id: u64,
    what: String,

    #[toql(join)]
    user: User 
}

并对它们进行操作

let toql = ...
let todo = Todo{ ... };

// Insert todo and update its generated id
toql.insert_one(&mut todo, paths!(top)).await?; 

// Compile time checked queries!
let q = query!(Todo, "*, user_id eq ?", &todo.user.id); 

// Typesafe loading
let todos = toql.load_many(q).await?; 

快速入门

查看CRUD示例

贡献

欢迎评论、错误修复和质量改进。

许可

Toql以MIT许可和Apache许可证(版本2.0)的条款进行分发。

依赖关系

~7–17MB
~212K SLoC