keyv 0.3.0

Simple key-value storage with support for multiple backends
Documentation
#[cfg(feature = "mysql")]
use keyv::{adapter::mysql::MySqlStoreBuilder, Keyv};

/* To run the test run the docker mysql
docker run --name keyv-mysql-test \
-e MYSQL_ROOT_PASSWORD=my-secret-pw \
-e MYSQL_DATABASE=keyv_test \
-e MYSQL_USER=user \
-e MYSQL_PASSWORD=password \
-p 3306:3306 \
-d mysql:latest
*/
#[cfg(feature = "mysql")]
#[tokio::main]
async fn main() {
    let store = MySqlStoreBuilder::new()
        .uri("mysql://user:password@localhost/keyv_test")
        .build()
        .await
        .unwrap();

    let keyv = Keyv::try_new(store).await.unwrap();
    keyv.set("number", 42).await.unwrap();
    keyv.set("number", 10).await.unwrap();
    keyv.set("array", vec!["hola", "test"]).await.unwrap();
    keyv.set("string", "life long").await.unwrap();

    match keyv.get("number").await.unwrap() {
        Some(number) => {
            let number: i32 = serde_json::from_value(number).unwrap();
            println!("number: {}", number);
        }
        None => println!("number not found"),
    }

    match keyv.get("string").await.unwrap() {
        Some(string) => {
            let string: String = serde_json::from_value(string).unwrap();
            println!("string: {}", string);
        }
        None => println!("string not found"),
    }

    match keyv.get("array").await.unwrap() {
        Some(array) => {
            let array: Vec<String> = serde_json::from_value(array).unwrap();
            println!("array: {:?}", array);
        }
        None => println!("array not found"),
    }
}

#[cfg(not(feature = "mysql"))]
fn main() {
    println!("This example requires the 'mysql' feature to be enabled.");
    println!("Please run the command as follows:");
    println!("cargo run --example mysql --features mysql");
}