pub struct PgConnection { /* private fields */ }Expand description
A connection to a PostgreSQL database.
See PgConnectOptions for connection URL reference.
Implementations§
Source§impl PgConnection
 
impl PgConnection
Sourcepub fn server_version_num(&self) -> Option<u32>
 
pub fn server_version_num(&self) -> Option<u32>
the version number of the server in libpq format
Source§impl PgConnection
 
impl PgConnection
Sourcepub async fn copy_in_raw(
    &mut self,
    statement: &str,
) -> Result<PgCopyIn<&mut Self>>
 
pub async fn copy_in_raw( &mut self, statement: &str, ) -> Result<PgCopyIn<&mut Self>>
Issue a COPY FROM STDIN statement and transition the connection to streaming data
to Postgres. This is a more efficient way to import data into Postgres as compared to
INSERT but requires one of a few specific data formats (text/CSV/binary).
If statement is anything other than a COPY ... FROM STDIN ... command, an error is
returned.
Command examples and accepted formats for COPY data are shown here:
https://www.postgresql.org/docs/current/sql-copy.html
§Note
PgCopyIn::finish or PgCopyIn::abort must be called when finished or the connection will return an error the next time it is used.
Sourcepub async fn copy_out_raw<'c>(
    &'c mut self,
    statement: &str,
) -> Result<BoxStream<'c, Result<Bytes>>>
 
pub async fn copy_out_raw<'c>( &'c mut self, statement: &str, ) -> Result<BoxStream<'c, Result<Bytes>>>
Issue a COPY TO STDOUT statement and transition the connection to streaming data
from Postgres. This is a more efficient way to export data from Postgres but
arrives in chunks of one of a few data formats (text/CSV/binary).
If statement is anything other than a COPY ... TO STDOUT ... command,
an error is returned.
Note that once this process has begun, unless you read the stream to completion, it can only be canceled in two ways:
- by closing the connection, or:
- by using another connection to kill the server process that is sending the data as shown in this StackOverflow answer.
If you don’t read the stream to completion, the next time the connection is used it will need to read and discard all the remaining queued data, which could take some time.
Command examples and accepted formats for COPY data are shown here:
https://www.postgresql.org/docs/current/sql-copy.html
Trait Implementations§
Source§impl<'c> Acquire<'c> for &'c mut PgConnection
 
impl<'c> Acquire<'c> for &'c mut PgConnection
Source§impl<C: AsMut<PgConnection>> AsMut<PgConnection> for PgAdvisoryLockGuard<C>
Mutable access to the underlying connection is provided so it can still be used like normal,
even allowing locks to be taken recursively.
 
impl<C: AsMut<PgConnection>> AsMut<PgConnection> for PgAdvisoryLockGuard<C>
Mutable access to the underlying connection is provided so it can still be used like normal, even allowing locks to be taken recursively.
However, replacing the connection with a different one using, e.g. std::mem::replace()
is a logic error and will cause a warning to be logged by the PostgreSQL server when this
guard attempts to release the lock.
Source§fn as_mut(&mut self) -> &mut PgConnection
 
fn as_mut(&mut self) -> &mut PgConnection
Source§impl AsMut<PgConnection> for PgConnection
 
impl AsMut<PgConnection> for PgConnection
Source§fn as_mut(&mut self) -> &mut PgConnection
 
fn as_mut(&mut self) -> &mut PgConnection
Source§impl<C: AsMut<PgConnection> + AsRef<PgConnection>> AsRef<PgConnection> for PgAdvisoryLockGuard<C>
 
impl<C: AsMut<PgConnection> + AsRef<PgConnection>> AsRef<PgConnection> for PgAdvisoryLockGuard<C>
Source§fn as_ref(&self) -> &PgConnection
 
fn as_ref(&self) -> &PgConnection
Source§impl Connection for PgConnection
 
impl Connection for PgConnection
type Database = Postgres
type Options = PgConnectOptions
Source§async fn close(self) -> Result<(), Error>
 
async fn close(self) -> Result<(), Error>
Source§async fn ping(&mut self) -> Result<(), Error>
 
async fn ping(&mut self) -> Result<(), Error>
Source§fn begin(
    &mut self,
) -> impl Future<Output = Result<Transaction<'_, Self::Database>, Error>> + Send + '_
 
fn begin( &mut self, ) -> impl Future<Output = Result<Transaction<'_, Self::Database>, Error>> + Send + '_
Source§fn begin_with(
    &mut self,
    statement: impl SqlSafeStr,
) -> impl Future<Output = Result<Transaction<'_, Self::Database>, Error>> + Send + '_where
    Self: Sized,
 
fn begin_with(
    &mut self,
    statement: impl SqlSafeStr,
) -> impl Future<Output = Result<Transaction<'_, Self::Database>, Error>> + Send + '_where
    Self: Sized,
Source§fn cached_statements_size(&self) -> usize
 
fn cached_statements_size(&self) -> usize
Source§async fn clear_cached_statements(&mut self) -> Result<(), Error>
 
async fn clear_cached_statements(&mut self) -> Result<(), Error>
Source§fn shrink_buffers(&mut self)
 
fn shrink_buffers(&mut self)
Source§fn is_in_transaction(&self) -> bool
 
fn is_in_transaction(&self) -> bool
true if the connection is currently in a transaction. Read moreSource§fn transaction<'a, F, R, E>(
    &'a mut self,
    callback: F,
) -> impl Future<Output = Result<R, E>> + Send + 'a
 
fn transaction<'a, F, R, E>( &'a mut self, callback: F, ) -> impl Future<Output = Result<R, E>> + Send + 'a
Source§impl Debug for PgConnection
 
impl Debug for PgConnection
Source§impl<'c> Executor<'c> for &'c mut PgConnection
 
impl<'c> Executor<'c> for &'c mut PgConnection
type Database = Postgres
Source§fn fetch_many<'e, 'q, E>(
    self,
    query: E,
) -> BoxStream<'e, Result<Either<PgQueryResult, PgRow>, Error>>
 
fn fetch_many<'e, 'q, E>( self, query: E, ) -> BoxStream<'e, Result<Either<PgQueryResult, PgRow>, Error>>
Source§fn fetch_optional<'e, 'q, E>(
    self,
    query: E,
) -> BoxFuture<'e, Result<Option<PgRow>, Error>>
 
fn fetch_optional<'e, 'q, E>( self, query: E, ) -> BoxFuture<'e, Result<Option<PgRow>, Error>>
Source§fn prepare_with<'e>(
    self,
    sql: SqlStr,
    parameters: &'e [PgTypeInfo],
) -> BoxFuture<'e, Result<PgStatement, Error>>where
    'c: 'e,
 
fn prepare_with<'e>(
    self,
    sql: SqlStr,
    parameters: &'e [PgTypeInfo],
) -> BoxFuture<'e, Result<PgStatement, Error>>where
    'c: 'e,
Source§fn execute<'e, 'q, E>(
    self,
    query: E,
) -> Pin<Box<dyn Future<Output = Result<<Self::Database as Database>::QueryResult, Error>> + Send + 'e>>
 
fn execute<'e, 'q, E>( self, query: E, ) -> Pin<Box<dyn Future<Output = Result<<Self::Database as Database>::QueryResult, Error>> + Send + 'e>>
Source§fn execute_many<'e, 'q, E>(
    self,
    query: E,
) -> Pin<Box<dyn Stream<Item = Result<<Self::Database as Database>::QueryResult, Error>> + Send + 'e>>
 
fn execute_many<'e, 'q, E>( self, query: E, ) -> Pin<Box<dyn Stream<Item = Result<<Self::Database as Database>::QueryResult, Error>> + Send + 'e>>
Source§fn fetch<'e, 'q, E>(
    self,
    query: E,
) -> Pin<Box<dyn Stream<Item = Result<<Self::Database as Database>::Row, Error>> + Send + 'e>>
 
fn fetch<'e, 'q, E>( self, query: E, ) -> Pin<Box<dyn Stream<Item = Result<<Self::Database as Database>::Row, Error>> + Send + 'e>>
Source§fn fetch_all<'e, 'q, E>(
    self,
    query: E,
) -> Pin<Box<dyn Future<Output = Result<Vec<<Self::Database as Database>::Row>, Error>> + Send + 'e>>
 
fn fetch_all<'e, 'q, E>( self, query: E, ) -> Pin<Box<dyn Future<Output = Result<Vec<<Self::Database as Database>::Row>, Error>> + Send + 'e>>
Vec.Auto Trait Implementations§
impl Freeze for PgConnection
impl !RefUnwindSafe for PgConnection
impl Send for PgConnection
impl Sync for PgConnection
impl Unpin for PgConnection
impl !UnwindSafe for PgConnection
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
 
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more