Struct sqlx_core::pool::PoolConnection
source · [−]pub struct PoolConnection<DB: Database> { /* private fields */ }
Expand description
A connection managed by a Pool
.
Will be returned to the pool on-drop.
Implementations
sourceimpl<DB: Database> PoolConnection<DB>
impl<DB: Database> PoolConnection<DB>
sourcepub fn detach(self) -> DB::Connection
pub fn detach(self) -> DB::Connection
Detach this connection from the pool, allowing it to open a replacement.
Note that if your application uses a single shared pool, this
effectively lets the application exceed the max_connections
setting.
If min_connections
is nonzero, a task will be spawned to replace this connection.
If you want the pool to treat this connection as permanently checked-out,
use .leak()
instead.
sourcepub fn leak(self) -> DB::Connection
pub fn leak(self) -> DB::Connection
Detach this connection from the pool, treating it as permanently checked-out.
This effectively will reduce the maximum capacity of the pool by 1 every time it is used.
If you don’t want to impact the pool’s capacity, use .detach()
instead.
Trait Implementations
sourceimpl<'c> Acquire<'c> for &'c mut PoolConnection<Postgres>
impl<'c> Acquire<'c> for &'c mut PoolConnection<Postgres>
type Database = Postgres
type Connection = &'c mut <Postgres as Database>::Connection
fn acquire(self) -> BoxFuture<'c, Result<Self::Connection, Error>>
fn begin(self) -> BoxFuture<'c, Result<Transaction<'c, Postgres>, Error>>
sourceimpl<'c> Acquire<'c> for &'c mut PoolConnection<Sqlite>
impl<'c> Acquire<'c> for &'c mut PoolConnection<Sqlite>
type Database = Sqlite
type Connection = &'c mut <Sqlite as Database>::Connection
fn acquire(self) -> BoxFuture<'c, Result<Self::Connection, Error>>
fn begin(self) -> BoxFuture<'c, Result<Transaction<'c, Sqlite>, Error>>
sourceimpl<DB: Database> AsMut<<DB as Database>::Connection> for PoolConnection<DB>
impl<DB: Database> AsMut<<DB as Database>::Connection> for PoolConnection<DB>
sourcefn as_mut(&mut self) -> &mut DB::Connection
fn as_mut(&mut self) -> &mut DB::Connection
Converts this type into a mutable reference of the (usually inferred) input type.
sourceimpl<DB: Database> AsRef<<DB as Database>::Connection> for PoolConnection<DB>
impl<DB: Database> AsRef<<DB as Database>::Connection> for PoolConnection<DB>
sourcefn as_ref(&self) -> &DB::Connection
fn as_ref(&self) -> &DB::Connection
Converts this type into a shared reference of the (usually inferred) input type.
sourceimpl<DB: Database> Debug for PoolConnection<DB>
impl<DB: Database> Debug for PoolConnection<DB>
sourceimpl<DB: Database> Deref for PoolConnection<DB>
impl<DB: Database> Deref for PoolConnection<DB>
sourceimpl<DB: Database> DerefMut for PoolConnection<DB>
impl<DB: Database> DerefMut for PoolConnection<DB>
sourceimpl<DB: Database> Drop for PoolConnection<DB>
impl<DB: Database> Drop for PoolConnection<DB>
Returns the connection to the Pool
it was checked-out from.
sourceimpl<'c> Executor<'c> for &'c mut PoolConnection<Postgres>
impl<'c> Executor<'c> for &'c mut PoolConnection<Postgres>
type Database = Postgres
sourcefn fetch_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<Either<<Postgres as Database>::QueryResult, PgRow>, Error>> where
'c: 'e,
E: Execute<'q, Postgres>,
fn fetch_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<Either<<Postgres as Database>::QueryResult, PgRow>, Error>> where
'c: 'e,
E: Execute<'q, Postgres>,
Execute multiple queries and return the generated results as a stream from each query, in a stream. Read more
sourcefn fetch_optional<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Option<PgRow>, Error>> where
'c: 'e,
E: Execute<'q, Postgres>,
fn fetch_optional<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Option<PgRow>, Error>> where
'c: 'e,
E: Execute<'q, Postgres>,
Execute the query and returns at most one row.
sourcefn prepare_with<'e, 'q: 'e>(
self,
sql: &'q str,
parameters: &'e [<Postgres as Database>::TypeInfo]
) -> BoxFuture<'e, Result<<Postgres as HasStatement<'q>>::Statement, Error>> where
'c: 'e,
fn prepare_with<'e, 'q: 'e>(
self,
sql: &'q str,
parameters: &'e [<Postgres as Database>::TypeInfo]
) -> BoxFuture<'e, Result<<Postgres as HasStatement<'q>>::Statement, Error>> where
'c: 'e,
Prepare the SQL query, with parameter type information, to inspect the type information about its parameters and results. Read more
sourcefn execute<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn execute<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return the total number of rows affected.
sourcefn execute_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn execute_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute multiple queries and return the rows affected from each query, in a stream.
sourcefn fetch<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::Row, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn fetch<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::Row, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return the generated results as a stream.
sourcefn fetch_all<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Vec<<Self::Database as Database>::Row>, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn fetch_all<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Vec<<Self::Database as Database>::Row>, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return all the generated results, collected into a Vec
.
sourceimpl<'c> Executor<'c> for &'c mut PoolConnection<Sqlite>
impl<'c> Executor<'c> for &'c mut PoolConnection<Sqlite>
type Database = Sqlite
sourcefn fetch_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<Either<<Sqlite as Database>::QueryResult, SqliteRow>, Error>> where
'c: 'e,
E: Execute<'q, Sqlite>,
fn fetch_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<Either<<Sqlite as Database>::QueryResult, SqliteRow>, Error>> where
'c: 'e,
E: Execute<'q, Sqlite>,
Execute multiple queries and return the generated results as a stream from each query, in a stream. Read more
sourcefn fetch_optional<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Option<SqliteRow>, Error>> where
'c: 'e,
E: Execute<'q, Sqlite>,
fn fetch_optional<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Option<SqliteRow>, Error>> where
'c: 'e,
E: Execute<'q, Sqlite>,
Execute the query and returns at most one row.
sourcefn prepare_with<'e, 'q: 'e>(
self,
sql: &'q str,
parameters: &'e [<Sqlite as Database>::TypeInfo]
) -> BoxFuture<'e, Result<<Sqlite as HasStatement<'q>>::Statement, Error>> where
'c: 'e,
fn prepare_with<'e, 'q: 'e>(
self,
sql: &'q str,
parameters: &'e [<Sqlite as Database>::TypeInfo]
) -> BoxFuture<'e, Result<<Sqlite as HasStatement<'q>>::Statement, Error>> where
'c: 'e,
Prepare the SQL query, with parameter type information, to inspect the type information about its parameters and results. Read more
sourcefn execute<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn execute<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return the total number of rows affected.
sourcefn execute_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn execute_many<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::QueryResult, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute multiple queries and return the rows affected from each query, in a stream.
sourcefn fetch<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::Row, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn fetch<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxStream<'e, Result<<Self::Database as Database>::Row, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return the generated results as a stream.
sourcefn fetch_all<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Vec<<Self::Database as Database>::Row>, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
fn fetch_all<'e, 'q: 'e, E: 'q>(
self,
query: E
) -> BoxFuture<'e, Result<Vec<<Self::Database as Database>::Row>, Error>> where
'c: 'e,
E: Execute<'q, Self::Database>,
Execute the query and return all the generated results, collected into a Vec
.
Auto Trait Implementations
impl<DB> !RefUnwindSafe for PoolConnection<DB>
impl<DB> Send for PoolConnection<DB>
impl<DB> Sync for PoolConnection<DB> where
<DB as Database>::Connection: Sync,
impl<DB> Unpin for PoolConnection<DB> where
<DB as Database>::Connection: Unpin,
impl<DB> !UnwindSafe for PoolConnection<DB>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> ToHex for T where
T: AsRef<[u8]>,
impl<T> ToHex for T where
T: AsRef<[u8]>,
sourcefn encode_hex<U>(&self) -> U where
U: FromIterator<char>,
fn encode_hex<U>(&self) -> U where
U: FromIterator<char>,
Encode the hex strict representing self
into the result. Lower case
letters are used (e.g. f9b4ca
) Read more
sourcefn encode_hex_upper<U>(&self) -> U where
U: FromIterator<char>,
fn encode_hex_upper<U>(&self) -> U where
U: FromIterator<char>,
Encode the hex strict representing self
into the result. Upper case
letters are used (e.g. F9B4CA
) Read more