3 releases

0.1.2 May 29, 2022
0.1.1 May 29, 2022
0.1.0 May 29, 2022
0.0.1 May 16, 2022

#2143 in Database interfaces

MIT and GPL-3.0 licenses

56KB
1.5K SLoC

Etanol-rs

this crate is still under development!

Usage:

in etanol/schema.etanol

    config {
        database = env("DATABASE")
        database_url = env("DATABASE_URL")
    }

    table User {
        id String @id
        name String
        age Integer? 
        isAdmin Boolean? @default(false)
    }

in .env

    DATABASE="sqlite"
    DATABASE_URL="testing.sqlite"

execute this commands

    // for install etanol command line interface
    $ cargo install etanol

    // for generate migration and models
    $ etanol migrate dev --name [name of migration]

in src/main.rs

    use etanol::{ModelWhere, QueryValue};

    mod database;

    use database::{create_connection, user::User};

    fn main() {
        create_connection();

        // Insert
        let user = User {
            id: "5".to_string(),
            age: Some(5),
            name: "Teste".to_string(),
            ..User::default()
        };

        user.insert().execute();

        // FindOne
        let _user = User::find()
            .field(ModelWhere::Equal("name", "Random"))
            .load()
            .unwrap();

        // FindMany
        let _users = User::find()
            .field(ModelWhere::Equal("name", "Random"))
            .many()
            .load()
            .unwrap();

        // Update
        User::update()
            .field(ModelWhere::Equal("id", "1"))
            .value(QueryValue("name", "Matheus"))
            .execute()
            .unwrap();

        // delete
        User::delete().field(ModelWhere::Equal("id", "1")).execute();
    }

Dependencies

~27MB
~512K SLoC