Trait sqlx::Connection
source · [−]pub trait Connection: Send {
type Database: Database;
type Options: ConnectOptions
where
<Self::Options as ConnectOptions>::Connection == Self;
fn close(
self
) -> Pin<Box<dyn Future<Output = Result<(), Error>> + Send + 'static, Global>>;
fn ping(
&mut self
) -> Pin<Box<dyn Future<Output = Result<(), Error>> + Send, Global>>;
fn begin(
&mut self
) -> Pin<Box<dyn Future<Output = Result<Transaction<'_, Self::Database>, Error>> + Send, Global>>;
fn transaction<'a, F, R, E>(
&'a mut self,
callback: F
) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'a, Global>>
where
F: 'a + for<'c, '_> FnOnce(&'c mut Transaction<'_, Self::Database>) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'c, Global>> + Send + Sync,
R: Send,
E: From<Error> + Send,
{ ... }
fn cached_statements_size(&self) -> usize
where
Self::Database: HasStatementCache,
{ ... }
fn clear_cached_statements(
&mut self
) -> Pin<Box<dyn Future<Output = Result<(), Error>> + Send, Global>>
where
Self::Database: HasStatementCache,
{ ... }
fn connect(
url: &str
) -> Pin<Box<dyn Future<Output = Result<Self, Error>> + Send + 'static, Global>> { ... }
fn connect_with(
options: &Self::Options
) -> Pin<Box<dyn Future<Output = Result<Self, Error>> + Send, Global>> { ... }
}
Expand description
Represents a single database connection.
Required Associated Types
type Options: ConnectOptions
where
<Self::Options as ConnectOptions>::Connection == Self
Required Methods
Explicitly close this database connection.
This method is not required for safe and consistent operation. However, it is
recommended to call it instead of letting a connection drop
as the database backend
will be faster at cleaning up resources.
Checks if a connection to the database is still valid.
Provided Methods
fn transaction<'a, F, R, E>(
&'a mut self,
callback: F
) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'a, Global>> where
F: 'a + for<'c, '_> FnOnce(&'c mut Transaction<'_, Self::Database>) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'c, Global>> + Send + Sync,
R: Send,
E: From<Error> + Send,
fn transaction<'a, F, R, E>(
&'a mut self,
callback: F
) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'a, Global>> where
F: 'a + for<'c, '_> FnOnce(&'c mut Transaction<'_, Self::Database>) -> Pin<Box<dyn Future<Output = Result<R, E>> + Send + 'c, Global>> + Send + Sync,
R: Send,
E: From<Error> + Send,
Execute the function inside a transaction.
If the function returns an error, the transaction will be rolled back. If it does not return an error, the transaction will be committed.
Example
use sqlx_core::connection::Connection;
use sqlx_core::error::Error;
use sqlx_core::executor::Executor;
use sqlx_core::postgres::{PgConnection, PgRow};
use sqlx_core::query::query;
conn.transaction(|conn|Box::pin(async move {
query("select * from ..").fetch_all(conn).await
})).await
fn cached_statements_size(&self) -> usize where
Self::Database: HasStatementCache,
fn cached_statements_size(&self) -> usize where
Self::Database: HasStatementCache,
The number of statements currently cached in the connection.
Removes all statements from the cache, closing them on the server if needed.
Establish a new database connection.
A value of Options
is parsed from the provided connection string. This parsing
is database-specific.