11 releases (breaking)

0.9.0 Oct 24, 2024
0.8.1 May 14, 2024
0.8.0 Mar 31, 2024
0.7.0 Nov 14, 2023
0.1.0 May 30, 2021

#2508 in Database interfaces

Download history 1680/week @ 2024-09-27 1900/week @ 2024-10-04 1812/week @ 2024-10-11 1596/week @ 2024-10-18 1454/week @ 2024-10-25 2553/week @ 2024-11-01 1635/week @ 2024-11-08 1703/week @ 2024-11-15 2444/week @ 2024-11-22 2498/week @ 2024-11-29 2333/week @ 2024-12-06 1886/week @ 2024-12-13 1378/week @ 2024-12-20 922/week @ 2024-12-27 1925/week @ 2025-01-03 2063/week @ 2025-01-10

6,547 downloads per month
Used in 19 crates (10 directly)

MIT/Apache

92KB
1.5K SLoC

Deadpool for SQLite Latest Version Unsafe forbidden Rust 1.75+

Deadpool is a dead simple async pool for connections and objects of any type.

This crate implements a deadpool manager for rusqlite and provides a wrapper that ensures correct use of the connection inside a separate thread.

Features

Feature Description Extra dependencies Default
rt_tokio_1 Enable support for tokio crate deadpool/rt_tokio_1 yes
rt_async-std_1 Enable support for async-std crate deadpool/rt_async-std_1 no
serde Enable support for serde crate deadpool/serde, serde/derive no
tracing Enable support for tracing by propagating Spans in the interact() calls. Enable this if you use the tracing crate and you want to get useful traces from within interact() calls. deadpool-sync/tracing, tracing no

Example

use deadpool_sqlite::{Config, Runtime};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let mut cfg = Config::new("db.sqlite3");
    let pool = cfg.create_pool(Runtime::Tokio1).unwrap();
    let conn = pool.get().await.unwrap();
    let result: i64 = conn
        .interact(|conn| {
            let mut stmt = conn.prepare("SELECT 1")?;
            let mut rows = stmt.query([])?;
            let row = rows.next()?.unwrap();
            row.get(0)
        })
        .await??;
    assert_eq!(result, 1);
    Ok(())
}

License

Licensed under either of

at your option.

Dependencies

~24–34MB
~560K SLoC