mirror of
https://github.com/launchbadge/sqlx.git
synced 2025-12-29 21:00:54 +00:00
73 lines
2.3 KiB
Rust
73 lines
2.3 KiB
Rust
use crate::database::{Database, HasCursor};
|
|
use crate::describe::Describe;
|
|
use futures_core::future::BoxFuture;
|
|
use futures_core::stream::BoxStream;
|
|
use futures_util::TryStreamExt;
|
|
|
|
/// A type that contains or can provide a database connection to use for executing queries
|
|
/// against the database.
|
|
///
|
|
/// No guarantees are provided that successive queries run on the same physical database
|
|
/// connection. A [`Connection`](trait.Connection.html) is an `Executor` that guarantees that successive
|
|
/// queries are run on the same physical database connection.
|
|
///
|
|
/// Implementations are provided for [`&Pool`](struct.Pool.html),
|
|
/// [`&mut PoolConnection`](struct.PoolConnection.html),
|
|
/// and [`&mut Connection`](trait.Connection.html).
|
|
pub trait Executor<'c>
|
|
where
|
|
Self: Send,
|
|
{
|
|
/// The specific database that this type is implemented for.
|
|
type Database: Database;
|
|
|
|
/// Executes a query that may or may not return a result set.
|
|
fn execute<'q, E>(self, query: E) -> <Self::Database as HasCursor<'c, 'q>>::Cursor
|
|
where
|
|
E: Execute<'q, Self::Database>;
|
|
|
|
#[doc(hidden)]
|
|
fn execute_by_ref<'b, E>(&mut self, query: E) -> <Self::Database as HasCursor<'_, 'b>>::Cursor
|
|
where
|
|
E: Execute<'b, Self::Database>;
|
|
}
|
|
|
|
/// A type that may be executed against a database connection.
|
|
pub trait Execute<'q, DB>
|
|
where
|
|
DB: Database,
|
|
{
|
|
/// Returns the query to be executed and the arguments to bind against the query, if any.
|
|
///
|
|
/// Returning `None` for `Arguments` indicates to use a "simple" query protocol and to not
|
|
/// prepare the query. Returning `Some(Default::default())` is an empty arguments object that
|
|
/// will be prepared (and cached) before execution.
|
|
#[doc(hidden)]
|
|
fn into_parts(self) -> (&'q str, Option<DB::Arguments>);
|
|
}
|
|
|
|
impl<'q, DB> Execute<'q, DB> for &'q str
|
|
where
|
|
DB: Database,
|
|
{
|
|
#[inline]
|
|
fn into_parts(self) -> (&'q str, Option<DB::Arguments>) {
|
|
(self, None)
|
|
}
|
|
}
|
|
|
|
macro_rules! impl_execute_for_query {
|
|
($db:ty) => {
|
|
impl<'q> $crate::executor::Execute<'q, $db> for $crate::query::Query<'q, $db> {
|
|
fn into_parts(
|
|
self,
|
|
) -> (
|
|
&'q str,
|
|
Option<<$db as $crate::database::Database>::Arguments>,
|
|
) {
|
|
(self.query, Some(self.arguments))
|
|
}
|
|
}
|
|
};
|
|
}
|