pub struct PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,{ /* private fields */ }postgres only.Expand description
A wrapper for PgConnection (or a similar type) that represents a held Postgres advisory lock.
Can be acquired by PgAdvisoryLock::acquire() or PgAdvisoryLock::try_acquire().
Released on-drop or via Self::release_now().
§Note: Release-on-drop is not immediate!
On drop, this guard queues a pg_advisory_unlock() call on the connection which will be
flushed to the server the next time it is used, or when it is returned to
a PgPool in the case of
PoolConnection<Postgres>.
This means the lock is not actually released as soon as the guard is dropped. To ensure the
lock is eagerly released, you can call .release_now().await.
Implementations§
Source§impl<'lock, C> PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
 
impl<'lock, C> PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
Sourcepub async fn release_now(self) -> Result<C, Error>
 
pub async fn release_now(self) -> Result<C, Error>
Immediately release the held advisory lock instead of when the connection is next used.
An error should only be returned if there is something wrong with the connection, in which case the lock will be automatically released by the connection closing anyway.
If pg_advisory_unlock() returns false, a warning will be logged, both by SQLx as
well as the Postgres server. This would only happen if the lock was released without
using this guard, or the connection was swapped using std::mem::replace().
Sourcepub fn leak(self) -> C
 
pub fn leak(self) -> C
Cancel the release of the advisory lock, keeping it held until the connection is closed.
To manually release the lock later, see PgAdvisoryLock::force_release().
Methods from Deref<Target = 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
Sourcepub async fn copy_in_raw(
    &mut self,
    statement: &str,
) -> Result<PgCopyIn<&mut PgConnection>, Error>
 
pub async fn copy_in_raw( &mut self, statement: &str, ) -> Result<PgCopyIn<&mut PgConnection>, Error>
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<Pin<Box<dyn Stream<Item = Result<Bytes, Error>> + Send + 'c>>, Error>
 
pub async fn copy_out_raw<'c>( &'c mut self, statement: &str, ) -> Result<Pin<Box<dyn Stream<Item = Result<Bytes, Error>> + Send + 'c>>, Error>
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<'lock, C> AsMut<PgConnection> for PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
Mutable access to the underlying connection is provided so it can still be used like normal,
even allowing locks to be taken recursively.
 
impl<'lock, C> AsMut<PgConnection> for PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
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<'lock, C> AsRef<PgConnection> for PgAdvisoryLockGuard<'lock, C>
 
impl<'lock, C> AsRef<PgConnection> for PgAdvisoryLockGuard<'lock, C>
Source§fn as_ref(&self) -> &PgConnection
 
fn as_ref(&self) -> &PgConnection
Source§impl<'lock, C> Deref for PgAdvisoryLockGuard<'lock, C>
 
impl<'lock, C> Deref for PgAdvisoryLockGuard<'lock, C>
Source§type Target = PgConnection
 
type Target = PgConnection
Source§impl<'lock, C> DerefMut for PgAdvisoryLockGuard<'lock, 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<'lock, C> DerefMut for PgAdvisoryLockGuard<'lock, 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§impl<'lock, C> Drop for PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
Queues a pg_advisory_unlock() call on the wrapped connection which will be flushed
to the server the next time it is used, or when it is returned to PgPool
in the case of PoolConnection<Postgres>.
 
impl<'lock, C> Drop for PgAdvisoryLockGuard<'lock, C>where
    C: AsMut<PgConnection>,
Queues a pg_advisory_unlock() call on the wrapped connection which will be flushed
to the server the next time it is used, or when it is returned to PgPool
in the case of PoolConnection<Postgres>.
Auto Trait Implementations§
impl<'lock, C> Freeze for PgAdvisoryLockGuard<'lock, C>where
    C: Freeze,
impl<'lock, C> RefUnwindSafe for PgAdvisoryLockGuard<'lock, C>where
    C: RefUnwindSafe,
impl<'lock, C> Send for PgAdvisoryLockGuard<'lock, C>where
    C: Send,
impl<'lock, C> Sync for PgAdvisoryLockGuard<'lock, C>where
    C: Sync,
impl<'lock, C> Unpin for PgAdvisoryLockGuard<'lock, C>where
    C: Unpin,
impl<'lock, C> UnwindSafe for PgAdvisoryLockGuard<'lock, C>where
    C: UnwindSafe,
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> 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