Expand description
§Serde Postgres
Easily deserialize rows from postgres into arbitrary structs. (Only deserialization is supported).
This works with following postgres client libraries:
use std::error::Error;
use serde::Deserialize;
use tokio_postgres::{connect, NoTls};
#[derive(Clone, Debug, Deserialize)]
struct Person {
name: String,
age: i32,
}
#[tokio::main]
async fn main() -> Result<(), Box<dyn Error>> {
let (client, conn) = connect("postgres://postgres@localhost:5432", NoTls).await?;
tokio::spawn(async move { conn.await.unwrap() });
client.execute(
"CREATE TABLE IF NOT EXISTS Person (
name VARCHAR NOT NULL,
age INT NOT NULL
)",
&[]
).await?;
client.execute("INSERT INTO Person (name, age) VALUES ($1, $2)", &[&"Jane", &23]).await?;
client.execute("INSERT INTO Person (name, age) VALUES ($1, $2)", &[&"Alice", &32]).await?;
let rows = client.query("SELECT name, age FROM Person", &[]).await?;
let people: Vec<Person> = serde_postgres::from_rows(&rows)?;
for person in people {
println!("{:?}", person);
}
Ok(())
}
Re-exports§
pub use de::from_row;
pub use de::from_rows;
pub use de::Deserializer;
pub use de::DeError;
pub use de::DeResult;
Modules§
- de
- Deserialize postgres rows into a Rust data structure.