#sqlx #interval #postgresql #serialize-deserialize #serde #com #pg-interval

sqlx-postgres-interval

sqlx INTERVAL Postgres type with serde Serialize/Deserialize

1 unstable release

0.1.0 Dec 19, 2024

#664 in Encoding

Download history 104/week @ 2024-12-17

104 downloads per month

MIT license

17KB
156 lines

sqlx-postgres-interval

The "current" (2024-12-18) version of sqlx (GitHub) for Postgres (0.8.2) does not derive serde::Serialize or serde::Deserialize for its type, sqlx::postgres::types::PgInterval, that represents the Postgres INTERVAL type.

Usage

Just add this crate and use its type:

use serde::{Deserialize, Serialize};
#[derive(sqlx::FromRow, Clone, Debug, PartialEq, Serialize, Deserialize)]
pub struct Video {
    pub id: i32,
    pub title: String,
    // ...
    pub duration: Option<sqlx_postgres_interval::Interval>,
}

Features

The chrono and time features will convert to/from their respective Durations. I haven't fully tested this; the code is copied verbatim from the current sqlx::postgres::types::PgInterval implementations.

Motivation

My database has a couple INTERVAL fields, and I don't want to have to manually implement these in my project, therefore, this crate now exists. Hopefully it will be obsoleted if serde::Serialize and serde::Deserialize get implemented for it (check at https://github.com/launchbadge/sqlx/blob/main/sqlx-postgres/src/types/interval.rs).

Unfortunately, one cannot implement serde (or any other external traits) for another external crate, hence the need to wrap the values.

Implementation

This crate wraps sqlx::postgres::types::PgInterval in its sqlx::Decode and sqlx::Encode implementations, and uses the pg_interval crate to Serialize/Deserialize it to/fron String.

Dependencies

~13–25MB
~380K SLoC