Easily deserialize rows from tokio-postgres
or postgres
into
arbitrary structs. (Only deserialization is supported).
tokio-postgres
(asynchronous)
```rust use std::error::Error; use serde::Deserialize; use tokio_postgres::{connect, NoTls};
struct Person { name: String, age: i32, }
async fn main() -> Result<(), Box
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", &23i32]).await?;
client.execute("INSERT INTO Person (name, age) VALUES ($1, $2)",
&[&"Alice", &32i32]).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(())
} ```
postgres
(synchronous)
```rust use postgres::{Client, NoTls}; use serde::Deserialize; use std::error::Error;
struct Person { name: String, age: i32, }
fn main() -> Result<(), Box
client.execute("CREATE TABLE IF NOT EXISTS Person (
name VARCHAR NOT NULL,
age INT NOT NULL
)", &[])?;
client.execute("INSERT INTO Person (name, age) VALUES ($1, $2)",
&[&"Jane", &23i32])?;
client.execute("INSERT INTO Person (name, age) VALUES ($1, $2)",
&[&"Alice", &32i32])?;
let rows = client.query("SELECT name, age FROM Person", &[])?;
let people: Vec<Person> = serde_postgres::from_rows(&rows)?;
for person in people {
println!("{:?}", person);
}
Ok(())
} ```