use sea_query::{SelectStatement, SqliteQueryBuilder};
use sea_query_sqlx::SqlxBinder;
use sqlx::RusqliteConnection;
use crate::{
Connection, debug_print,
rusqlite_types::{RusqliteError, RusqliteRow},
};
pub struct Executor {
pool: RusqliteConnection,
}
pub trait IntoExecutor {
fn into_executor(self) -> Executor;
}
impl IntoExecutor for RusqliteConnection {
fn into_executor(self) -> Executor {
Executor { pool: self }
}
}
impl Connection for Executor {
fn query_all(&self, select: SelectStatement) -> Result<Vec<RusqliteRow>, RusqliteError> {
let (sql, values) = select.build_sqlx(SqliteQueryBuilder);
debug_print!("{}, {:?}", sql, values);
Ok(sqlx::query_with(&sql, values)
.fetch_all(&mut *self.pool.acquire()?)?
.into_iter()
.map(RusqliteRow::Sqlite)
.collect())
}
fn query_all_raw(&self, sql: String) -> Result<Vec<RusqliteRow>, RusqliteError> {
debug_print!("{}", sql);
Ok(sqlx::query(&sql)
.fetch_all(&mut *self.pool.acquire()?)?
.into_iter()
.map(RusqliteRow::Sqlite)
.collect())
}
}