首页 > 解决方案 > 为 sqlx 值创建适配器

问题描述

我在应用程序中具有通用特征,可以跨不同存储转换结果。现在我想添加对 SQLx 的支持。我想让它对所有 sqlx 引擎保持通用。
i64 的简化示例:

// My trait
pub trait TryConvert {
    fn try_i64(&self) -> i64;
}

首先实现尝试:

// Gives error
// the trait `sqlx::Decode<'_, DB>` is not implemented for `i64`
impl<DB, V> TryConvert for V
where
    DB: Database,
    V: Value<Database = DB>,
{
    fn try_i64(&self) -> i64 {
        self.try_decode_unchecked().unwrap()
    }
}

现在Decode对于 i64:

// Gives error:
// expected `sqlx::Decode<'_, DB>` found `sqlx::Decode<'a, DB>`
impl<'a, DB, V> TryConvert for V
where
    DB: Database,
    V: Value<Database = DB>,
    i64: Decode<'a, DB>,
{
    fn try_i64(&self) -> i64 {
        self.try_decode_unchecked().unwrap()
    }
}

但都适用于具体的数据库类型:

impl<V> TryConvert for V
where
    V: Value<Database = Sqlite>,
{
    fn try_i64(&self) -> i64 {
        self.try_decode_unchecked().unwrap()
    }
}

是否可以保留TryConvert任何 sqlx 数据库引擎的通用性?

标签: rustsqlx

解决方案


感谢kmdreko。最终的解决方案:

impl<DB, V> TryConvert for V
where
    DB: Database,
    V: Value<Database = DB>,
    i64: for <'a> Decode<'a, DB>,
{
    fn try_i64(&self) -> i64 {
        self.try_decode_unchecked().unwrap()
    }
}

关于<'_> 的更多信息


推荐阅读