gpt4 book ai didi

rust - 具有定制包装类型的柴油机

转载 作者:行者123 更新时间:2023-12-03 11:43:00 25 4
gpt4 key购买 nike

我有自定义类型,可用作 Diesel 中无法安全使用的其他类型的包装器:

use uuid::Uuid;

pub schema Post {
id: PostId,
title: String,
body: String
}

pub schema PostId {value: Uuid}

我无法将这些自定义包装器与 Diesel 一起使用。我收到的错误消息如下:

#[derive(Insertable)]
the trait `diesel::Expression` is not implemented for `models::PostId`

我尝试寻找有关转换自定义类型的示例,到目前为止,我看到的两种方法是实现 AsExpression 特征或 FromSqlToSql 特征,但到目前为止我看到的示例都是针对枚举类型的,我无法推断这两种方法之间有什么区别,除了前者似乎是一种较旧的方法,也不知道这些特征的预期实现是什么。

最佳答案

根据 weiznich 的回答,我提出了以下用于序列化/反序列化自定义包装类型的解决方案:

use uuid::Uuid;
use super::schema::posts;
use diesel::serialize::{self, IsNull, Output, ToSql};
use std::io::Write;
use diesel::deserialize::{self, FromSql};
use diesel::backend::Backend;
use diesel::pg::Pg;

#[derive(Queryable, Debug)]
pub struct Post {
pub id: PostId,
pub body: String,
pub title: String
}

#[derive(Insertable)]
#[table_name="posts"]
pub struct NewPost<'a> {
pub id: PostId,
pub body: &'a str,
pub title: &'a str
}

#[derive(AsExpression, FromSqlRow, Debug)]
#[sql_type = "diesel::sql_types::Uuid"]
pub struct PostId{pub value: Uuid}

impl<DB: Backend<RawValue=[u8]>> FromSql<diesel::sql_types::Uuid, DB> for PostId {
fn from_sql(bytes: Option<&DB::RawValue>) -> deserialize::Result<Self> {
<uuid::Uuid as FromSql<diesel::sql_types::Uuid, Pg>>::from_sql(bytes).map(|value| PostId{ value })
}
}

impl ToSql<diesel::sql_types::Uuid, Pg> for PostId {
fn to_sql<W: Write>(&self, out: &mut Output<W, Pg>) -> serialize::Result {
<uuid::Uuid as ToSql<diesel::sql_types::Uuid, Pg>>::to_sql(&self.value, out)
}
}

关于rust - 具有定制包装类型的柴油机,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62746540/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com