25 releases

0.4.5 Oct 26, 2024
0.4.1 Sep 6, 2024
0.3.7 Jul 19, 2024
0.3.1 Mar 11, 2024
0.1.7 May 18, 2023

#80 in Database interfaces

Download history 254/week @ 2024-07-27 13/week @ 2024-08-03 152/week @ 2024-08-10 54/week @ 2024-08-17 46/week @ 2024-08-24 68/week @ 2024-08-31 165/week @ 2024-09-07 113/week @ 2024-09-14 112/week @ 2024-09-21 278/week @ 2024-09-28 473/week @ 2024-10-05 159/week @ 2024-10-12 93/week @ 2024-10-19 382/week @ 2024-10-26 62/week @ 2024-11-02 30/week @ 2024-11-09

574 downloads per month
Used in welds-cli

BSD-3-Clause

350KB
9K SLoC

An async ORM written in rust using sqlx and/or Tiberius.

Welds

Welds is an async ORM written in rust using sqlx and/or Tiberius.

Features

  • Async for all.
  • Support for multiple SQL databases (Mssql, MySql, Postgres, Sqlite)
  • Written for ease of development. Features aren't hidden behind traits. Code should be simple to write, and simple to read.
  • Low level connection always available when you need to drop down to raw SQL.

Under the hood welds uses:

  • sqlx for Postgres, MySql, and Sqlite.
  • Tiberius for MSSQL

Compatibility:

  • the 0.4.* line of welds is compiled with sqlx 0.8
  • the 0.3.* line of welds is compiled with sqlx 0.7

Example Setup

#[derive(Debug, WeldsModel)]
#[welds(schema= "inventory", table = "products")]
#[welds(BelongsTo(seller, super::people::People, "seller_id"))]
pub struct Product {
    #[welds(rename = "product_id")]
    #[welds(primary_key)]
    pub id: i32,
    pub name: String,
    pub seller_id: Option<i32>,
    pub description: Option<String>,
    pub price: Option<f32>,
}

Example Usage

Basic Select

  let url = "postgres://postgres:password@localhost:5432";
  let client = welds::connections::postgres::connect(url).await.unwrap();

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

Basic Filter Across tables

  let client = welds::connections::mssql::connect(url).await.unwrap();

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

Create And Update

  let client = welds::connections::sqlite::connect(url).await.unwrap();

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

Other Examples

For more good examples check out the examples repo.

Dependencies

~1–20MB
~267K SLoC