#toql #table #query #field #sql #parameters #orm

toql_derive

带有toql derive的库

6个版本

0.4.0 2021年12月4日
0.3.0 2021年10月20日
0.1.4 2019年5月20日

#9 in #toql

每月下载量:29
3个crate中使用(通过toql

MIT/Apache

265KB
5.5K SLoC

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)的条款进行分发。

依赖项

~4–14MB
~146K SLoC