sql >> Databáze >  >> RDS >> PostgreSQL

vlastnost `diesel::Expression` není implementována pro `bigdecimal::BigDecimal`

Diesel používá funkce Cargo k přihlášení k rozšířeným funkcím.

Nenašel jsem k nim jasnou dokumentační stránku, ale jsou uvedeny v Cargo.toml:

[features]
default = ["with-deprecated", "32-column-tables"]
extras = ["chrono", "serde_json", "uuid", "deprecated-time", "network-address", "numeric", "r2d2"]
unstable = ["diesel_derives/nightly"]
large-tables = ["32-column-tables"]
huge-tables = ["64-column-tables"]
x32-column-tables = ["32-column-tables"]
32-column-tables = []
x64-column-tables = ["64-column-tables"]
64-column-tables = ["32-column-tables"]
x128-column-tables = ["128-column-tables"]
128-column-tables = ["64-column-tables"]
postgres = ["pq-sys", "bitflags", "diesel_derives/postgres"]
sqlite = ["libsqlite3-sys", "diesel_derives/sqlite"]
mysql = ["mysqlclient-sys", "url", "diesel_derives/mysql"]
with-deprecated = []
deprecated-time = ["time"]
network-address = ["ipnetwork", "libc"]
numeric = ["num-bigint", "bigdecimal", "num-traits", "num-integer"]

Musíte povolit numerické a ujistěte se, že používáte verzi bigdecimal, která je kompatibilní s Diesel:

[dependencies]
diesel = { version = "1.4.2", features = ["numeric"] }
bigdecimal = "0.0.14"

A kód se zkompiluje:

#[macro_use]
extern crate diesel;

use crate::schema::threads;
use bigdecimal::BigDecimal;

mod schema {
    table! {
        threads (id) {
            id -> Int4,
            bounty -> Numeric,
        }
    }
}

#[derive(Debug, Insertable)]
#[table_name = "threads"]
pub struct InsertableThread {
    pub bounty: BigDecimal,
}

Viz také:

  • Proč není vlastnost implementována pro typ, který ji má jasně implementovanou?


  1. Jak získat aktuální čas (bez časového pásma) v PostgreSQL

  2. Bring Your Own Cloud (BYOC) vs. Dedikovaný hosting na ScaleGrid

  3. Způsoby migrace databáze SQL Server do Azure SQL Database

  4. Přehled typů SQL Join s příklady