Thanks to visit codestin.com
Credit goes to lib.rs

1 unstable release

0.1.0 Jun 7, 2024

#119 in #env-file


Used in sqlm-postgres

MIT/Apache

39KB
952 lines

sqlm

An sql! macro to write compile-time checked database queries similar to how format! works.

Documentation

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 dependencies

    cargo 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