2 unstable releases

0.2.0 May 13, 2024
0.1.9 Dec 8, 2023

#1377 in Database interfaces

MIT/Apache

77KB
1.5K SLoC

An easy-to use basic mssql server ORM based on tiberius.

This crate is still under construction, apis may subject to change.
For full documentation pls visit doc.rs.

Quick Glance:

When defining structs, make sure keep the field sequence consistent with the sequence in database as bulk insert(insert_many) depends on it.

use ssql::prelude::*;
use serde::{Deserialize, Serialize};

#[derive(ORM, Debug, Default, Serialize, Deserialize)]
#[ssql(table = Person, schema = SCHEMA1)] // other schema
struct Person {
    #[ssql(primary_key)]
    id: i32,
    email: Option<String>, // wrap nullable column in option
}

#[derive(ORM, Debug, Default, Serialize, Deserialize)]
#[ssql(table = Posts)] // default schema
struct Posts {
    id: i32,
    post: String,
    #[ssql(foreign_key = "SCHEMA1.Person.id")] // if it belongs to default schema, just write TABLE.COLUMN
    person_id: i32,
}

async fn _get<'a>(client: &'a mut tiberius::Client<Compat<TcpStream>>) -> SsqlResult<()> { 
    let mut query = Person::query();

    // return Vec<Person>
    let vec1 = query.all(client).await?;

    // return Vec<Value>
    let js = query.json(client).await?;

    // return Polars DataFrame
    let df = query.df(client).await?;

    // return Vec<(Person, Posts)>
    let query = query.left_join::<Posts>();
    let vec2 = query.all(client).await?;

    Ok(())
}

TODO:

  • handle multiple relationships
  • build filter pattern
  • support raw sql string query
  • handle non-manual input key like auto-generated id
  • handle GROUP BY aggregation
  • support filter with decorated col like WHERE YEAR(datetime_col) = ?

Dependencies

~8–20MB
~329K SLoC