1 unstable release
0.1.0 | Jun 7, 2024 |
---|
#119 in #env-file
Used in sqlm-postgres
39KB
952 lines
sqlm
An sql!
macro to write compile-time checked database queries similar to how format!
works.
Example
let id: i64 = 1;
let user: User = sql!("SELECT * FROM users WHERE id = {id}").await?;
#[derive(Debug, FromRow)]
struct User {
id: i64,
name: String,
role: Role,
}
#[derive(Debug, Default, FromSql, ToSql, Enum)]
#[postgres(name = "role")]
enum Role {
#[default]
#[postgres(name = "user")]
User,
#[postgres(name = "admin")]
Admin,
}
Usage
-
Add
sqlm-postgres
to your dependenciescargo add sqlm-postgres
-
Make the
DATABASE_URL
env variable available during compile time (e.g. via adding an.env
file)echo DATABASE_URL=postgres://your-user@localhost/your-db > .env
-
Start using the
sql!
macro (no further setup necessary; a connection pool is automatically created for you)
License
Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~20–32MB
~577K SLoC