Redrock Postgres Documentation
Home Toggle Dark/Light/Auto mode Toggle Dark/Light/Auto mode Toggle Dark/Light/Auto mode Back to homepage

Connection classes

The Connection and AsyncConnection classes are the main wrappers for a PostgreSQL database session. You can imagine them similar to a psql session.

One of the differences compared to psql is that a Connection usually handles a transaction automatically: other sessions will not be able to see the changes until you have committed them, more or less explicitly. Take a look to Transactions management for the details.

The Connection class

class psycopg.Connection(pgconn, row_factory=<function tuple_row>)

Wrapper for a connection to the database.

This class implements a DBAPI-compliant interface. It is what you want to use if you write a “classic”, blocking program (eventually using threads or Eventlet/gevent for concurrency). If your program uses asyncio you might want to use AsyncConnection instead.

Connections behave as context managers: on block exit, the current transaction will be committed (or rolled back, in case of exception) and the connection will be closed.

Connection.connect()

classmethod connect(conninfo='', *, autocommit=False, prepare_threshold=5, row_factory=None, cursor_factory=None, context=None, **kwargs)

Connect to a database server and return a new Connection instance.

RETURN TYPE:

Connection[Any]

PARAMETERS:

  • conninfo – The connection string (a postgresql:// url or a list of key=value pairs) to specify where and how to connect.
  • kwargs – Further parameters specifying the connection string. They override the ones specified in !conninfo.
  • autocommit – If !True don’t start transactions automatically. See Transactions management for details.
  • row_factory – The row factory specifying what type of records to create fetching data (default: ~psycopg.rows.tuple_row()). See Row factories for details.
  • cursor_factory – Initial value for the cursor_factory attribute of the connection (new in Psycopg 3.1).
  • prepare_threshold – Initial value for the prepare_threshold attribute of the connection (new in Psycopg 3.1).

More specialized use:

PARAMETERS:

  • context – A context to copy the initial adapters configuration from. It might be an ~psycopg.adapt.AdaptersMap with customized loaders and dumpers, used as a template to create several connections. See Data adaptation configuration for further details.

This method is also aliased as psycopg.connect().

Changed in version 3.1: added !prepare_threshold and !cursor_factory parameters.

Connection.close()

close()

Close the database connection.

You can use:

with psycopg.connect() as conn:
    ...

to close the connection automatically when the block is exited. See Connection context.

Connection.closed

closed

!True if the connection is closed.

Connection.broken

broken

!True if the connection was interrupted.A broken connection is always closed, but wasn’t closed in a clean way, such as using close() or a !with block.

Connection.cursor()

cursor(*, binary: bool = False, row_factory: Optional[RowFactory] = None) → Cursor

cursor(name: str, *, binary: bool = False, row_factory: Optional[RowFactory] = None, scrollable: Optional[bool] = None, withhold: bool = False) → ServerCursor

Return a new cursor to send commands and queries to the connection.

PARAMETERS:

  • name – If not specified create a client-side cursor, if specified create a server-side cursor. See Cursor types for details.
  • binary – If !True return binary values from the database. All the types returned by the query must have a binary loader. See Binary parameters and results for details.
  • row_factory – If specified override the row_factory set on the connection. See Row factories for details.
  • scrollable – Specify the ~ServerCursor.scrollable property of the server-side cursor created.
  • withhold – Specify the ~ServerCursor.withhold property of the server-side cursor created.

RETURNS:

A cursor of the class specified by cursor_factory (or server_cursor_factory if !name is specified).

You can use:

with conn.cursor() as cur:
    ...

to close the cursor automatically when the block is exited.

Connection.cursor_factory

cursor_factory: Type[Cursor[TypeVar(Row, covariant=True)]]

The type, or factory function, returned by cursor() and execute().

Default is psycopg.Cursor.

Connection.server_cursor_factory

server_cursor_factory: Type[ServerCursor[TypeVar(Row, covariant=True)]]

The type, or factory function, returned by cursor() when a name is specified.

Default is psycopg.ServerCursor.

Connection.row_factory

row_factory: RowFactory[TypeVar(Row, covariant=True)]

The row factory defining the type of rows returned by ~Cursor.fetchone() and the other cursor fetch methods.

The default is ~psycopg.rows.tuple_row, which means that the fetch methods will return simple tuples.

See Row factories for details about defining the objects returned by cursors.

Connection.execute()

execute(query, params=None, *, prepare=None, binary=False)

Execute a query and return a cursor to read its results.

RETURN TYPE:

Cursor[TypeVar(Row, covariant=True)]

PARAMETERS:

  • query (!str, !bytes, sql.SQL, or sql.Composed) – The query to execute.
  • params (Sequence or Mapping) – The parameters to pass to the query, if any.
  • prepare – Force (!True) or disallow (!False) preparation of the query. By default (!None) prepare automatically. See Prepared statements.
  • binary – If !True the cursor will return binary values from the database. All the types returned by the query must have a binary loader. See Binary parameters and results for details.

The method simply creates a Cursor instance, ~Cursor.execute() the query requested, and returns it.

See Passing parameters to SQL queries for all the details about executing queries.

Connection.pipeline()

pipeline()

Switch the connection into pipeline mode.

RETURN TYPE:

Iterator[Pipeline]

The method is a context manager: you should call it using:

with conn.pipeline() as p:
    ...

At the end of the block, a synchronization point is established and the connection returns in normal mode.

You can call the method recursively from within a pipeline block. Innermost blocks will establish a synchronization point on exit, but pipeline mode will be kept until the outermost block exits.

See Pipeline mode support for details.

New in version 3.1.

Transaction management methods

For details see Transactions management.

Connection.commit()

commit()

Commit any pending transaction to the database.

Connection.rollback()

rollback()

Roll back to the start of any pending transaction.

Connection.transaction()

transaction(savepoint_name=None, force_rollback=False)

Start a context block with a new transaction or nested transaction.

PARAMETERS:

  • savepoint_name (Optional[str]) – Name of the savepoint used to manage a nested transaction. If !None, one will be chosen automatically.
  • force_rollback (bool) – Roll back the transaction at the end of the block even if there were no error (e.g. to try a no-op process).

RETURN TYPE:

Transaction

The method must be called with a syntax such as:

with conn.transaction():
    ...

with conn.transaction() as tx:
    ...

The latter is useful if you need to interact with the Transaction object. See Transaction contexts for details.

Inside a transaction block it will not be possible to call commit() or rollback().

Connection.autocommit

autocommit

The autocommit state of the connection.

The property is writable for sync connections, read-only for async ones: you should call !await ~AsyncConnection.set_autocommit (value) instead.

The following three properties control the characteristics of new transactions. See Transaction characteristics for details.

Connection.isolation_level

isolation_level

The isolation level of the new transactions started on the connection.

!None means use the default set in the default_transaction_isolation configuration parameter of the server.

Connection.read_only

read_only

The read-only state of the new transactions started on the connection.

!None means use the default set in the default_transaction_read_only configuration parameter of the server.

Connection.deferrable

deferrable

The deferrable state of the new transactions started on the connection.

!None means use the default set in the default_transaction_deferrable configuration parameter of the server.

Checking and configuring the connection state

Connection.pgconn

pgconn: psycopg.pq.PGconn

The ~pq.PGconn libpq connection wrapper underlying the !Connection.

It can be used to send low level commands to PostgreSQL and access features not currently wrapped by Psycopg.

Connection.info

info

A ConnectionInfo attribute to inspect connection properties.

Connection.prepare_threshold

prepare_threshold

Number of times a query is executed before it is prepared.

  • If it is set to 0, every query is prepared the first time it is executed.
  • If it is set to !None, prepared statements are disabled on the connection.

Default value: 5

See Prepared statements for details.

Connection.prepared_max

prepared_max

Maximum number of prepared statements on the connection.

Default value: 100

If more queries need to be prepared, old ones are deallocated.

Methods you can use to do something cool

Connection.cancel()

cancel()

Cancel the current operation on the connection.

Connection.notifies()

notifies()

Yield Notify objects as soon as they are received from the database.

RETURN TYPE:

Generator[Notify, None, None]

Notifies are received after using LISTEN in a connection, when any sessions in the database generates a NOTIFY on one of the listened channels.

Connection.add_notify_handler()

add_notify_handler(callback)

Register a callable to be invoked whenever a notification is received.

PARAMETERS:

callback (Callable[[Notify], None]) – the callback to call upon notification received.

See Asynchronous notifications for details.

Connection.remove_notify_handler()

remove_notify_handler(callback)

Unregister a notification callable previously registered.

PARAMETERS:

callback (Callable[[Notify], None]) – the callback to remove.

Connection.add_notice_handler()

add_notice_handler(callback)

Register a callable to be invoked when a notice message is received.

PARAMETERS:

callback (Callable[[Diagnostic], None]) – the callback to call upon message received.

See Server messages for details.

Connection.remove_notice_handler()

remove_notice_handler(callback)

Unregister a notice message callable previously registered.

PARAMETERS:

callback (Callable[[Diagnostic], None]) – the callback to remove.

Connection.fileno()

fileno()

Return the file descriptor of the connection.

This function allows to use the connection as file-like object in functions waiting for readiness, such as the ones defined in the selectors module.

RETURN TYPE:

int

Two-Phase Commit support methods

New in version 3.1.

Two-Phase Commit protocol support for an introductory explanation of these methods.

Connection.xid()

xid(format_id, gtrid, bqual)

Returns a Xid to pass to the !tpc_*() methods of this connection.

The argument types and constraints are explained in Two-Phase Commit protocol support.

The values passed to the method will be available on the returned object as the members ~Xid.format_id, ~Xid.gtrid, ~Xid.bqual.

RETURN TYPE:

Xid

Connection.tpc_begin()

tpc_begin(xid)

Begin a TPC transaction with the given transaction ID !xid.

PARAMETERS:

  • xid (Xid or str) – The id of the transaction

This method should be called outside of a transaction (i.e. nothing may have executed since the last commit() or rollback() and ~ConnectionInfo.transaction_status is ~pq.TransactionStatus.IDLE).

Furthermore, it is an error to call !commit() or !rollback() within the TPC transaction: in this case a ProgrammingError is raised.

The !xid may be either an object returned by the xid() method or a plain string: the latter allows to create a transaction using the provided string as PostgreSQL transaction id. See also tpc_recover().

Connection.tpc_prepare()

tpc_prepare()

Perform the first phase of a transaction started with tpc_begin().

A ProgrammingError is raised if this method is used outside of a TPC transaction.

After calling !tpc_prepare(), no statements can be executed until tpc_commit() or tpc_rollback() will be called.

The PREPARE TRANSACTION PostgreSQL command.

Connection.tpc_commit()

tpc_commit(xid=None)

Commit a prepared two-phase transaction.

PARAMETERS:

  • xid (Xid or str) – The id of the transaction

When called with no arguments, !tpc_commit() commits a TPC transaction previously prepared with tpc_prepare().

If !tpc_commit() is called prior to !tpc_prepare(), a single phase commit is performed. A transaction manager may choose to do this if only a single resource is participating in the global transaction.

When called with a transaction ID !xid, the database commits the given transaction. If an invalid transaction ID is provided, a ProgrammingError will be raised. This form should be called outside of a transaction, and is intended for use in recovery.

On return, the TPC transaction is ended.

The COMMIT PREPARED PostgreSQL command.

Connection.tpc_rollback()

tpc_rollback(xid=None)

Roll back a prepared two-phase transaction.

PARAMETERS:

  • xid (Xid or str) – The id of the transaction

When called with no arguments, !tpc_rollback() rolls back a TPC transaction. It may be called before or after tpc_prepare().

When called with a transaction ID !xid, it rolls back the given transaction. If an invalid transaction ID is provided, a ProgrammingError is raised. This form should be called outside of a transaction, and is intended for use in recovery.

On return, the TPC transaction is ended.

The ROLLBACK PREPARED PostgreSQL command.

Connection.tpc_recover()

tpc_recover()

RETURN TYPE:

List[Xid]

Returns a list of Xid representing pending transactions, suitable for use with tpc_commit() or tpc_rollback().

If a transaction was not initiated by Psycopg, the returned Xids will have attributes ~Xid.format_id and ~Xid.bqual set to !None and the ~Xid.gtrid set to the PostgreSQL transaction ID: such Xids are still usable for recovery. Psycopg uses the same algorithm of the PostgreSQL JDBC driver to encode a XA triple in a string, so transactions initiated by a program using such driver should be unpacked correctly.

Xids returned by !tpc_recover() also have extra attributes ~Xid.prepared, ~Xid.owner, ~Xid.database populated with the values read from the server.

the pg_prepared_xacts system view.

The !AsyncConnection class

class psycopg.AsyncConnection(pgconn, row_factory=<function tuple_row>)

Asynchronous wrapper for a connection to the database.

This class implements a DBAPI-inspired interface, with all the blocking methods implemented as coroutines. Unless specified otherwise, non-blocking methods are shared with the Connection class.

The following methods have the same behaviour of the matching !Connection methods, but should be called using the await keyword.

AsyncConnection.connect()

async classmethod connect(conninfo='', *, autocommit=False, prepare_threshold=5, context=None, row_factory=None, cursor_factory=None, **kwargs)

RETURN TYPE:

AsyncConnection[Any]

Changed in version 3.1: Automatically resolve domain names asynchronously. In previous versions, name resolution blocks, unless the !hostaddr parameter is specified, or the ~psycopg._dns.resolve_hostaddr_async() function is used.

AsyncConnection.close()

async close()
You can use async with to close the connection automatically when the block is exited, but be careful about the async quirkness: see with async connections for details.

AsyncConnection.cursor()

cursor(*, binary: bool = False, row_factory: Optional[RowFactory] = None) → AsyncCursor

cursor(name: str, *, binary: bool = False, row_factory: Optional[RowFactory] = None, scrollable: Optional[bool] = None, withhold: bool = False) → AsyncServerCursor

You can use:

async with conn.cursor() as cur:
    ...

to close the cursor automatically when the block is exited.

AsyncConnection.cursor_factory

cursor_factory*: Type[AsyncCursor[TypeVar(Row, covariant=True)]]*

Default is psycopg.AsyncCursor.

AsyncConnection.server_cursor_factory

server_cursor_factory*: Type[AsyncServerCursor[TypeVar(Row, covariant=True)]]*

Default is psycopg.AsyncServerCursor.

AsyncConnection.row_factory

row_factory*: AsyncRowFactory[TypeVar(Row, covariant=True)]*

AsyncConnection.execute()

async execute(query, params=None, *, prepare=None, binary=False)

RETURN TYPE:

AsyncCursor[TypeVar(Row, covariant=True)]

AsyncConnection.pipeline()

pipeline()

Context manager to switch the connection into pipeline mode.

RETURN TYPE:

AsyncIterator[AsyncPipeline]

It must be called as:

async with conn.pipeline() as p:
    ...

AsyncConnection.commit()

async commit()

AsyncConnection.rollback()

async rollback()

AsyncConnection.transaction()

transaction(savepoint_name=None, force_rollback=False)

Start a context block with a new transaction or nested transaction.

RETURN TYPE:

AsyncTransaction

It must be called as:

async with conn.transaction() as tx:
    ...

AsyncConnection.notifies()

async notifies()

RETURN TYPE:

AsyncGenerator[Notify, None]

AsyncConnection.set_autocommit()

async set_autocommit(value)

Async version of the ~Connection.autocommit setter.

AsyncConnection.set_isolation_level()

async set_isolation_level(value)

Async version of the ~Connection.isolation_level setter.

AsyncConnection.set_read_only()

async set_read_only(value)

Async version of the ~Connection.read_only setter.

AsyncConnection.set_deferrable()

async set_deferrable(value)

Async version of the ~Connection.deferrable setter.

AsyncConnection.tpc_prepare()

async tpc_prepare()

AsyncConnection.tpc_commit()

async tpc_commit(xid=None)

AsyncConnection.tpc_rollback()

async tpc_rollback(xid=None)

AsyncConnection.tpc_recover()

async tpc_recover()

RETURN TYPE:

List[Xid]