7 releases (breaking)

0.6.0 Sep 20, 2024
0.5.1 Feb 26, 2024
0.5.0 Nov 25, 2023
0.4.0 Apr 2, 2023
0.1.0 Apr 25, 2022

#100 in Database interfaces

Download history 2386/week @ 2024-08-21 2287/week @ 2024-08-28 2488/week @ 2024-09-04 2691/week @ 2024-09-11 2773/week @ 2024-09-18 2828/week @ 2024-09-25 2862/week @ 2024-10-02 2667/week @ 2024-10-09 3159/week @ 2024-10-16 2974/week @ 2024-10-23 3237/week @ 2024-10-30 3037/week @ 2024-11-06 3932/week @ 2024-11-13 4169/week @ 2024-11-20 3090/week @ 2024-11-27 2945/week @ 2024-12-04

14,565 downloads per month
Used in 14 crates (13 directly)

MIT license

25KB
416 lines

License Crates.io Docs - Stable

tokio-rusqlite

Asynchronous handle for rusqlite library.

Usage

use tokio_rusqlite::{params, Connection, Result};

#[derive(Debug)]
struct Person {
    id: i32,
    name: String,
    data: Option<Vec<u8>>,
}

#[tokio::main]
async fn main() -> Result<()> {
    let conn = Connection::open_in_memory().await?;

    let people = conn
        .call(|conn| {
            conn.execute(
                "CREATE TABLE person (
                    id    INTEGER PRIMARY KEY,
                    name  TEXT NOT NULL,
                    data  BLOB
                )",
                [],
            )?;

            let steven =
                Person {
                    id: 1,
                    name: "Steven".to_string(),
                    data: None,
                };

            conn.execute(
                "INSERT INTO person (name, data) VALUES (?1, ?2)",
                params![steven.name, steven.data],
            )?;

            let mut stmt = conn.prepare("SELECT id, name, data FROM person")?;
            let people = stmt
                .query_map([], |row| {
                    Ok(Person {
                        id: row.get(0)?,
                        name: row.get(1)?,
                        data: row.get(2)?,
                    })
                })?
                .collect::<std::result::Result<Vec<Person>, rusqlite::Error>>()?;

            Ok(people)
        })
        .await?;

    for person in people {
        println!("Found person {person:?}");
    }

    conn.close().await?;
    Ok(())
}

Safety

This crate uses #![forbid(unsafe_code)] to ensure everything is implemented in 100% safe Rust.

License

This project is licensed under the MIT license.

Dependencies

~30MB
~472K SLoC