#query-builder #mysql #query #builder #rust

chain-builder

A query builder for MySQL for Rust is designed to be flexible and easy to use

23 releases

0.1.24 Apr 2, 2024
0.1.23 Feb 29, 2024
0.1.9 Jan 14, 2024

#480 in Database interfaces

Download history 9/week @ 2024-01-06 26/week @ 2024-01-13 16/week @ 2024-01-27 7/week @ 2024-02-03 19/week @ 2024-02-10 64/week @ 2024-02-17 118/week @ 2024-02-24 41/week @ 2024-03-02 6/week @ 2024-03-09 1/week @ 2024-03-16 170/week @ 2024-03-30 14/week @ 2024-04-06

186 downloads per month

MIT license

53KB
1.5K SLoC

Chain builder

Documentation Version License

A query builder for MySQL for Rust is designed to be flexible and easy to use.

Installation

cargo add chain-builder

Usage

use chain_builder::{ChainBuilder, Select, WhereClauses, Client};
use serde_json::{self, Value};

let mut builder = ChainBuilder::new(Client::Mysql);
builder.db("mydb"); // For dynamic db
builder.select(Select::Columns(vec!["*".into()]));
builder.table("users");
builder.query(|qb| {
    qb.where_eq("name", Value::String("John".to_string()));
    qb.where_eq("city", Value::String("New York".to_string()));
    qb.where_in(
        "department",
        vec![
            Value::String("IT".to_string()),
            Value::String("HR".to_string()),
        ],
    );
    qb.where_subquery(|sub| {
        sub.where_eq("status", Value::String("active".to_string()));
        sub.or()
            .where_eq("status", Value::String("pending".to_string()))
            .where_between(
                "registered_at",
                [
                    Value::String("2024-01-01".to_string()),
                    Value::String("2024-01-31".to_string()),
                ],
            );
    });
    qb.where_raw(
        "(latitude BETWEEN ? AND ?) AND (longitude BETWEEN ? AND ?)".into(),
        Some(vec![
            Value::Number(serde_json::Number::from_f64(40.0).unwrap()),
            Value::Number(serde_json::Number::from_f64(41.0).unwrap()),
            Value::Number(serde_json::Number::from_f64(70.0).unwrap()),
            Value::Number(serde_json::Number::from_f64(71.0).unwrap()),
        ]),
    );
});
let sql = builder.to_sql();
println!("final sql: {}", sql.0);
// SELECT * FROM mydb.users WHERE name = ? AND city = ? AND department IN (?,?) AND (status = ? OR (status = ? AND registered_at BETWEEN ? AND ?)) AND (latitude BETWEEN ? AND ?) AND (longitude BETWEEN ? AND ?)
println!("final binds: {:?}", sql.1);
// Some([String("John"), String("New York"), String("IT"), String("HR"), String("active"), String("pending"), String("2024-01-01"), String("2024-01-31"), Number(40.0), Number(41.0), Number(70.0), Number(71.0)])

Dependencies

~9–22MB
~324K SLoC