sql >> Databasteknik >  >> RDS >> PostgreSQL

egenskapen `diesel::Expression` är inte implementerad för `bigdecimal::BigDecimal`

Diesel använder Cargo-funktioner för att välja utökad funktionalitet.

Jag har inte hittat en tydlig dokumentationssida för dessa, men de finns listade i dess 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"]

Du måste aktivera numeriska och se till att du använder en version av bigdecimal som är kompatibel med Diesel:

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

Och koden kompilerar:

#[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,
}

Se även:

  • Varför implementeras inte en egenskap för en typ som uppenbarligen har den implementerad?


  1. IN vs ALLA operatör i PostgreSQL

  2. Hur delar jag upp utdata från mysqldump i mindre filer?

  3. Hur man lägger till identitetskolumn till tabell med TSQL och GUI i SQL Server - SQL Server / T-SQL självstudie del 40

  4. Varför ska du lära dig PostgreSQL?