Trait diesel::serialize::ToSql [] [src]

pub trait ToSql<A, DB: Backend>: Debug {
    fn to_sql<W: Write>(&self, out: &mut Output<W, DB>) -> Result;
}

Serializes a single value to be sent to the database.

The output is sent as a bind parameter, and the data must be written in the expected format for the given backend.

When possible, implementations of this trait should prefer using an existing implementation, rather than writing to out directly. (For example, if you are implementing this for an enum, which is represented as an integer in the database, you should use i32::to_sql(x, out) instead of writing to out yourself.

Any types which implement this trait should also #[derive(AsExpression)].

Backend specific details

  • For PostgreSQL, the bytes will be sent using the binary protocol, not text.
  • For SQLite, all implementations should be written in terms of an existing ToSql implementation.
  • For MySQL, the expected bytes will depend on the return value of type_metadata for the given SQL type. See MysqlType for details.
  • For third party backends, consult that backend's documentation.

Required Methods

See the trait documentation.

Implementations on Foreign Types

impl<'a, A, T: ?Sized, DB> ToSql<A, DB> for &'a T where
    DB: Backend,
    T: ToSql<A, DB>, 
[src]

[src]

impl ToSql<Datetime, Mysql> for MYSQL_TIME
[src]

[src]

impl ToSql<Timestamp, Mysql> for MYSQL_TIME
[src]

[src]

impl ToSql<Time, Mysql> for MYSQL_TIME
[src]

[src]

impl ToSql<Date, Mysql> for MYSQL_TIME
[src]

[src]

impl ToSql<Datetime, Mysql> for NaiveDateTime
[src]

[src]

impl ToSql<Timestamp, Mysql> for NaiveDateTime
[src]

[src]

impl ToSql<Time, Mysql> for NaiveTime
[src]

[src]

impl ToSql<Date, Mysql> for NaiveDate
[src]

[src]

impl ToSql<Numeric, Mysql> for BigDecimal
[src]

[src]

impl ToSql<Tinyint, Mysql> for i8
[src]

[src]

impl ToSql<Unsigned<SmallInt>, Mysql> for u16
[src]

[src]

impl ToSql<Unsigned<Integer>, Mysql> for u32
[src]

[src]

impl ToSql<Unsigned<BigInt>, Mysql> for u64
[src]

[src]

impl ToSql<Bool, Mysql> for bool
[src]

[src]

impl<ST, T> ToSql<Array<ST>, Pg> for [T] where
    Pg: HasSqlType<ST>,
    T: ToSql<ST, Pg>, 
[src]

[src]

impl<ST, T> ToSql<Nullable<Array<ST>>, Pg> for [T] where
    [T]: ToSql<Array<ST>, Pg>, 
[src]

[src]

impl<ST, T> ToSql<Array<ST>, Pg> for Vec<T> where
    [T]: ToSql<Array<ST>, Pg>,
    T: Debug
[src]

[src]

impl<ST, T> ToSql<Nullable<Array<ST>>, Pg> for Vec<T> where
    Vec<T>: ToSql<Array<ST>, Pg>, 
[src]

[src]

impl<ST, T> ToSql<Range<ST>, Pg> for (Bound<T>, Bound<T>) where
    T: ToSql<ST, Pg>, 
[src]

[src]

impl<ST, T> ToSql<Nullable<Range<ST>>, Pg> for (Bound<T>, Bound<T>) where
    (Bound<T>, Bound<T>): ToSql<Range<ST>, Pg>, 
[src]

[src]

impl ToSql<Timestamp, Pg> for SystemTime
[src]

[src]

impl ToSql<Timestamp, Pg> for NaiveDateTime
[src]

[src]

impl ToSql<Timestamptz, Pg> for NaiveDateTime
[src]

[src]

impl<TZ: TimeZone> ToSql<Timestamptz, Pg> for DateTime<TZ>
[src]

[src]

impl ToSql<Time, Pg> for NaiveTime
[src]

[src]

impl ToSql<Date, Pg> for NaiveDate
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamp>, __DB> for Timespec where
    __DB: Backend,
    Self: ToSql<Timestamp, __DB>, 
[src]

[src]

impl ToSql<Timestamp, Pg> for Timespec
[src]

[src]

impl<__DB> ToSql<Nullable<MacAddr>, __DB> for [u8; 6] where
    __DB: Backend,
    Self: ToSql<MacAddr, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Inet>, __DB> for IpNetwork where
    __DB: Backend,
    Self: ToSql<Inet, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Cidr>, __DB> for IpNetwork where
    __DB: Backend,
    Self: ToSql<Cidr, __DB>, 
[src]

[src]

impl ToSql<MacAddr, Pg> for [u8; 6]
[src]

[src]

impl ToSql<Inet, Pg> for IpNetwork
[src]

[src]

impl ToSql<Cidr, Pg> for IpNetwork
[src]

[src]

impl ToSql<Oid, Pg> for u32
[src]

[src]

impl ToSql<Numeric, Pg> for BigDecimal
[src]

[src]

impl ToSql<Bool, Pg> for bool
[src]

[src]

impl<__DB> ToSql<Nullable<Uuid>, __DB> for Uuid where
    __DB: Backend,
    Self: ToSql<Uuid, __DB>, 
[src]

[src]

impl ToSql<Uuid, Pg> for Uuid
[src]

[src]

impl<__DB> ToSql<Nullable<Json>, __DB> for Value where
    __DB: Backend,
    Self: ToSql<Json, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Jsonb>, __DB> for Value where
    __DB: Backend,
    Self: ToSql<Jsonb, __DB>, 
[src]

[src]

impl ToSql<Json, Pg> for Value
[src]

[src]

impl ToSql<Jsonb, Pg> for Value
[src]

[src]

impl ToSql<Date, Sqlite> for NaiveDate
[src]

[src]

impl ToSql<Time, Sqlite> for NaiveTime
[src]

[src]

impl ToSql<Timestamp, Sqlite> for NaiveDateTime
[src]

[src]

impl ToSql<Date, Sqlite> for str
[src]

[src]

impl ToSql<Date, Sqlite> for String
[src]

[src]

impl ToSql<Time, Sqlite> for str
[src]

[src]

impl ToSql<Time, Sqlite> for String
[src]

[src]

impl ToSql<Timestamp, Sqlite> for str
[src]

[src]

impl ToSql<Timestamp, Sqlite> for String
[src]

[src]

impl ToSql<Bool, Sqlite> for bool
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamp>, __DB> for SystemTime where
    __DB: Backend,
    Self: ToSql<Timestamp, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Date>, __DB> for NaiveDate where
    __DB: Backend,
    Self: ToSql<Date, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Time>, __DB> for NaiveTime where
    __DB: Backend,
    Self: ToSql<Time, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamp>, __DB> for NaiveDateTime where
    __DB: Backend,
    Self: ToSql<Timestamp, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamptz>, __DB> for NaiveDateTime where
    __DB: Backend,
    Self: ToSql<Timestamptz, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Datetime>, __DB> for NaiveDateTime where
    __DB: Backend,
    Self: ToSql<Datetime, __DB>, 
[src]

[src]

impl<Tz: TimeZone, __DB> ToSql<Nullable<Timestamptz>, __DB> for DateTime<Tz> where
    __DB: Backend,
    Self: ToSql<Timestamptz, __DB>, 
[src]

[src]

impl<DB: Backend> ToSql<Float, DB> for f32
[src]

[src]

impl<DB: Backend> ToSql<Double, DB> for f64
[src]

[src]

impl<DB: Backend> ToSql<SmallInt, DB> for i16
[src]

[src]

impl<DB: Backend> ToSql<Integer, DB> for i32
[src]

[src]

impl<DB: Backend> ToSql<BigInt, DB> for i64
[src]

[src]

impl<T, ST, DB> ToSql<Nullable<ST>, DB> for Option<T> where
    T: ToSql<ST, DB>,
    DB: Backend,
    ST: NotNull
[src]

[src]

impl<__DB> ToSql<Nullable<Bool>, __DB> for bool where
    __DB: Backend,
    Self: ToSql<Bool, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Tinyint>, __DB> for i8 where
    __DB: Backend,
    Self: ToSql<Tinyint, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<SmallInt>, __DB> for i16 where
    __DB: Backend,
    Self: ToSql<SmallInt, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Integer>, __DB> for i32 where
    __DB: Backend,
    Self: ToSql<Integer, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<BigInt>, __DB> for i64 where
    __DB: Backend,
    Self: ToSql<BigInt, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Unsigned<SmallInt>>, __DB> for u16 where
    __DB: Backend,
    Self: ToSql<Unsigned<SmallInt>, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Unsigned<Integer>>, __DB> for u32 where
    __DB: Backend,
    Self: ToSql<Unsigned<Integer>, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Oid>, __DB> for u32 where
    __DB: Backend,
    Self: ToSql<Oid, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Unsigned<BigInt>>, __DB> for u64 where
    __DB: Backend,
    Self: ToSql<Unsigned<BigInt>, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Float>, __DB> for f32 where
    __DB: Backend,
    Self: ToSql<Float, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Double>, __DB> for f64 where
    __DB: Backend,
    Self: ToSql<Double, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Text>, __DB> for String where
    __DB: Backend,
    Self: ToSql<Text, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Date>, __DB> for String where
    __DB: Backend,
    Self: ToSql<Date, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Time>, __DB> for String where
    __DB: Backend,
    Self: ToSql<Time, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamp>, __DB> for String where
    __DB: Backend,
    Self: ToSql<Timestamp, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Text>, __DB> for str where
    __DB: Backend,
    Self: ToSql<Text, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Date>, __DB> for str where
    __DB: Backend,
    Self: ToSql<Date, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Time>, __DB> for str where
    __DB: Backend,
    Self: ToSql<Time, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Timestamp>, __DB> for str where
    __DB: Backend,
    Self: ToSql<Timestamp, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Binary>, __DB> for Vec<u8> where
    __DB: Backend,
    Self: ToSql<Binary, __DB>, 
[src]

[src]

impl<__DB> ToSql<Nullable<Binary>, __DB> for [u8] where
    __DB: Backend,
    Self: ToSql<Binary, __DB>, 
[src]

[src]

impl<DB: Backend> ToSql<Text, DB> for str
[src]

[src]

impl<DB> ToSql<Text, DB> for String where
    DB: Backend,
    str: ToSql<Text, DB>, 
[src]

[src]

impl<DB> ToSql<Binary, DB> for Vec<u8> where
    DB: Backend,
    [u8]: ToSql<Binary, DB>, 
[src]

[src]

impl<DB: Backend> ToSql<Binary, DB> for [u8]
[src]

[src]

impl<'a, T: ?Sized, ST, DB> ToSql<ST, DB> for Cow<'a, T> where
    T: 'a + ToOwned + ToSql<ST, DB>,
    DB: Backend,
    Self: Debug
[src]

[src]

impl<__DB> ToSql<Nullable<Numeric>, __DB> for BigDecimal where
    __DB: Backend,
    Self: ToSql<Numeric, __DB>, 
[src]

[src]

Implementors