Welds

Welds is an async ORM written in rust using the sqlx framework.

Features

Example Setup

```rust

[derive(Debug, sqlx::FromRow, WeldsModel)]

[welds(db(Postgres))]

//#[welds(db(Postgres, Mssql, Mysql, Sqlite))]

[welds(schema= "inventory", table = "products")]

[welds(BelongsTo(seller, super::people::People, "seller_id"))]

pub struct Product { #[sqlx(rename = "productid")] #[welds(primarykey)] pub id: i32, pub name: String, pub seller_id: Option, pub description: Option, pub price: Option, } ```

Example Usage

Basic Select

```rust let conn: sqlx::PgPool = sqlx::PgPool::connect(&url).await.unwrap();

let products = Product::where_col(|p| p.price.equal(3.50)).run(&conn).await?; ```

Basic Filter Across tables

```rust let conn: sqlx::PgPool = sqlx::PgPool::connect(&url).await.unwrap();

let sellers = Product::wherecol(|product| product.price.equal(3.50)) .mapquery(|product| product.seller ) .where_col(|seller| seller.name.ilike("%Nessie%") ) .run(&conn).await?; ```

Create And Update

```rust let conn: sqlx::PgPool = sqlx::PgPool::connect(&url).await.unwrap();

let mut cookies = Product::new(); cookies.name = "cookies".toowned(); // Creates the product cookie cookies.save.await(&conn)?; cookies.description = "Yum".toowned(); // Updates the Cookies cookies.save.await(&conn)?; ```