为什么我无法为Diesel结构中的可选字段实现特征

时间:2018-10-23 05:20:23

标签: rust rust-diesel

我有这个结构:

#[table_name = "clients"]
#[derive(Serialize, Deserialize, Queryable, Insertable, Identifiable, Associations)]
pub struct Client {
    pub id: Option<i64>,
    pub name: String,
    pub rank: Option<i64>,
}

和以下实现:

impl Client {
    pub fn get(name: String, connection: &PgConnection) -> Option<Self> {
        match clients::table
            .filter(clients::name.eq(&name))
            .limit(1)
            .load::<Client>(connection)
        {
            Ok(clients) => Some(clients[0]),
            Err(_) => None,
        }
    }
}

这给了我以下错误:

.load::<Client>(connection) {                                                                                   
 ^^^^ the trait `diesel::Queryable<diesel::sql_types::BigInt, _>` is not implemented for `std::option::Option<i64>`

1 个答案:

答案 0 :(得分:3)

您的错误消息说,您无法将BigInt(64位int)查询到Option<i64>中。那是因为您忘记说id在您的table declaration中可以为空。它必须看起来像:

table! {
    clients {
        id -> Nullable<BigInt>,
        name -> Text,
        rank -> Nullable<BigInt>,
    }
}

您可以看到正在寻找in the documentationQueryable的实现。