Derive sqlx::FromRow
specific to the given database.
sqlx-derive-with supports decode
attribute to use custom decoder function to specific columns.
This feature is not (and unable to be, I think) supported by upstream sqlx::FromRow
.
```rust use sqlx::Connection as _;
struct Row { #[sqlxwith(decode = "splitx")] x: (i64, i64), y: String, }
fn splitx(index: &str, row: &sqlx::sqlite::SqliteRow) -> sqlx::Result<(i64, i64)> { use sqlx::Row as _; let n: i64 = row.tryget(index)?; Ok((n, n + 2)) }
async fn main() { let mut conn = sqlx::SqliteConnection::connect(":memory:").await.unwrap(); let row: Row = sqlx::queryas("select 10 as x, 'hello' as y") .fetchone(&mut conn) .await .unwrap(); asserteq!(row.x, (10, 12)); asserteq!(row.y, "hello"); } ```