Crate deadpool_sqlite[][src]

Expand description

Deadpool for SQLite Latest Version Unsafe forbidden Rust 1.54+

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

FeatureDescriptionExtra dependenciesDefault
rt_tokio_1Enable support for tokio cratedeadpool/rt_tokio_1yes
rt_async-std_1Enable support for async-std cratedeadpool/rt_async-std_1no
serdeEnable support for serde cratedeadpool/serde, serde/deriveno

Example

use deadpool_sqlite::{Config, Runtime};

#[tokio::main]
async fn main() {
    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
        .unwrap();
    assert_eq!(result, 1);
}

License

Licensed under either of

at your option.

Re-exports

pub use rusqlite;

Structs

Configuration object.

Manager for creating and recycling SQLite Connections.

Statistics regarding an object returned by the pool

Pool configuration.

The current pool status.

This guard is returned when calling SyncWrapper::lock or SyncWrapper::try_lock. This is basicly just a wrapper around a MutexGuard but hides some implementation details.

Timeouts when getting Objects from a Pool.

Enums

Possible errors returned when SyncWrapper::interact() fails.

Enumeration for picking a runtime implementation.

Type Definitions

This error is returned if there is something wrong with the SQLite configuration.

Type alias for Object

Type alias for using deadpool::managed::Hook with rusqlite.

Type alias for using deadpool::managed::Object with rusqlite.

Type alias for using deadpool::managed::Pool with rusqlite.