chrono-tz-postgres

crates.io Released API docs msrv 1.60

A timezone type that can be converted to and from a custom Postgres type. This allows you to use typed timezones in PostgreSQL.

The custom Postgres enum tz is equivalent to the Rust enum chrono_tz::Tz. It can be found here.

chrono-tz-postgres in action

```rust pub use chronotz::Tz; use chronotz_postgres::TzPg; use postgres::{Client, NoTls};

fn main() -> Result<(), Box> { // We can convert Tz into and from TzPg let tz = Tz::Arctic__Longyearbyen; let tzpg: TzPg = tz.into(); let tz: Tz = tzpg.into();

// Tz can be serialized, unlike TzPg
serde_json::to_string(&tz)?;

// but TzPg can interface with Postgres
let mut client = Client::connect("host=localhost user=postgres", NoTls)?;
let row = client.query_one("SELECT timezone FROM foo LIMIT 1", &[])?;
let tz: TzPg = row.get(0);

// Convert back to Tz to do more
let tz: Tz = tz.into();
println!("{tz}");

Ok(())

} ```