common¶
- advanced_alchemy.config.common.ALEMBIC_TEMPLATE_PATH = '/home/runner/work/advanced-alchemy/advanced-alchemy/advanced_alchemy/alembic/templates'¶
Path to the Alembic templates.
- class advanced_alchemy.config.common.ConnectionT¶
Type variable for SQLAlchemy connection types.
See also
sqlalchemy.Connection
sqlalchemy.ext.asyncio.AsyncConnection
alias of TypeVar(‘ConnectionT’, bound=
Connection
|AsyncConnection
)
- class advanced_alchemy.config.common.EngineT¶
Type variable for a SQLAlchemy engine.
See also
sqlalchemy.Engine
sqlalchemy.ext.asyncio.AsyncEngine
alias of TypeVar(‘EngineT’, bound=
Engine
|AsyncEngine
)
- class advanced_alchemy.config.common.GenericAlembicConfig[source]¶
Bases:
object
Configuration for Alembic’s
Config
.For details see: https://alembic.sqlalchemy.org/en/latest/api/config.html
- __init__(script_config='alembic.ini', version_table_name='alembic_versions', version_table_schema=None, script_location='migrations', user_module_prefix='sa.', render_as_batch=True, compare_type=False, template_path='/home/runner/work/advanced-alchemy/advanced-alchemy/advanced_alchemy/alembic/templates')¶
-
script_config:
str
= 'alembic.ini'¶ A path to the Alembic configuration file such as
alembic.ini
. If left unset, the default configuration will be used.
-
version_table_name:
str
= 'alembic_versions'¶ Configure the name of the table used to hold the applied alembic revisions. Defaults to
alembic_versions
.
- class advanced_alchemy.config.common.GenericSQLAlchemyConfig[source]¶
Bases:
Generic
[EngineT
,SessionT
,SessionMakerT
]Common SQLAlchemy Configuration.
- Types:
EngineT:
sqlalchemy.Engine
orsqlalchemy.ext.asyncio.AsyncEngine
SessionT:sqlalchemy.Session
orsqlalchemy.ext.asyncio.AsyncSession
SessionMakerT:sqlalchemy.orm.sessionmaker
orsqlalchemy.ext.asyncio.async_sessionmaker
- create_engine_callable: Callable[[str], EngineT]¶
Callable that creates an
AsyncEngine
instance or instance of its subclass.
- session_config: GenericSessionConfig[Any, Any, Any]¶
Configuration options for either the
async_sessionmaker
orsessionmaker
.
- session_maker_class: type[sessionmaker[Session] | async_sessionmaker[AsyncSession]]¶
Sessionmaker class to use.
- connection_string: str | None = None¶
Database connection string in one of the formats supported by SQLAlchemy.
Notes
For async connections, the connection string must include the correct async prefix. e.g.
'postgresql+asyncpg://...'
instead of'postgresql://'
, and for sync connections its the opposite.
- engine_config: EngineConfig¶
Configuration for the SQLAlchemy engine.
The configuration options are documented in the SQLAlchemy documentation.
- session_maker: Callable[[], SessionT] | None = None¶
Callable that returns a session.
If provided, the plugin will use this rather than instantiate a sessionmaker.
- engine_instance: EngineT | None = None¶
Optional engine to use.
If set, the plugin will use the provided instance rather than instantiate an engine.
- __init__(create_engine_callable, session_config, session_maker_class, connection_string=None, engine_config=<factory>, session_maker=None, engine_instance=None, create_all=False, metadata=None, enable_touch_updated_timestamp_listener=True, bind_key=None)¶
- create_all: bool = False¶
If true, all models are automatically created on engine creation.
- metadata: MetaData | None = None¶
Optional metadata to use.
If set, the plugin will use the provided instance rather than the default metadata.
- enable_touch_updated_timestamp_listener: bool = True¶
Enable Created/Updated Timestamp event listener.
This is a listener that will update
created_at
andupdated_at
columns on record modification. Disable if you plan to bring your own update mechanism for these columns
- bind_key: str | None = None¶
Bind key to register a metadata to a specific engine configuration.
- property engine_config_dict: dict[str, Any]¶
Return the engine configuration as a dict.
- Returns:
A string keyed dict of config kwargs for the SQLAlchemy
sqlalchemy.get_engine()
function.
- property session_config_dict: dict[str, Any]¶
Return the session configuration as a dict.
- Returns:
A string keyed dict of config kwargs for the SQLAlchemy
sqlalchemy.orm.sessionmaker
class.
- get_engine()[source]¶
Return an engine. If none exists yet, create one.
- Return type:
sqlalchemy.engine.Engine
- Returns:
sqlalchemy.Engine
orsqlalchemy.ext.asyncio.AsyncEngine
instance used by the plugin.
- create_session_maker()[source]¶
Get a session maker. If none exists yet, create one.
- Return type:
Callable
[[], sqlalchemy.orm.Session]- Returns:
sqlalchemy.orm.sessionmaker
orsqlalchemy.ext.asyncio.async_sessionmaker
factory used by the plugin.
- class advanced_alchemy.config.common.GenericSessionConfig[source]¶
Bases:
Generic
[ConnectionT
,EngineT
,SessionT
]SQLAlchemy async session config.
- Types:
ConnectionT:
sqlalchemy.Connection
|sqlalchemy.ext.asyncio.AsyncConnection
EngineT:sqlalchemy.Engine
|sqlalchemy.ext.asyncio.AsyncEngine
SessionT:sqlalchemy.Session
|sqlalchemy.ext.asyncio.AsyncSession
- autobegin¶
Automatically start transactions when database access is requested by an operation.
Bool or
Empty
alias of
Empty
- autoflush¶
When
True
, all query operations will issue a flush call to thisSession
before proceedingalias of
Empty
- bind¶
The
Engine
orConnection
that newSession
objects will be bound to.alias of
Empty
- binds¶
A dictionary which may specify any number of
Engine
orConnection
objects as the source of connectivity for SQL operations on a per-entity basis. The keys of the dictionary consist of any series of mapped classes, arbitrary Python classes that are bases for mapped classes,Table
objects andMapper
objects. The values of the dictionary are then instances ofEngine
or less commonlyConnection
objects.alias of
Empty
- info¶
Optional dictionary of information that will be available via the
Session.info
alias of
Empty
- join_transaction_mode¶
Describes the transactional behavior to take when a given bind is a Connection that has already begun a transaction outside the scope of this Session; in other words the
Connection.in_transaction()
method returns True.alias of
Empty
- query_cls¶
Class which should be used to create new Query objects, as returned by the
Session.query()
method.alias of
Empty
- twophase¶
When
True
, all transactions will be started as a “two phase” transaction, i.e. using the “two phase” semantics of the database in use along with an XID. During acommit()
, afterflush()
has been issued for all attached databases, theTwoPhaseTransaction.prepare()
method on each database`sTwoPhaseTransaction
will be called. This allows each database to roll back the entire transaction, before each transaction is committed.alias of
Empty
- __init__(autobegin=<class 'advanced_alchemy.utils.dataclass.Empty'>, autoflush=<class 'advanced_alchemy.utils.dataclass.Empty'>, bind=<class 'advanced_alchemy.utils.dataclass.Empty'>, binds=<class 'advanced_alchemy.utils.dataclass.Empty'>, class_=<class 'advanced_alchemy.utils.dataclass.Empty'>, expire_on_commit=<class 'advanced_alchemy.utils.dataclass.Empty'>, info=<class 'advanced_alchemy.utils.dataclass.Empty'>, join_transaction_mode=<class 'advanced_alchemy.utils.dataclass.Empty'>, query_cls=<class 'advanced_alchemy.utils.dataclass.Empty'>, twophase=<class 'advanced_alchemy.utils.dataclass.Empty'>)¶
- class advanced_alchemy.config.common.SessionMakerT¶
Type variable for a SQLAlchemy sessionmaker.
alias of TypeVar(‘SessionMakerT’, bound=
sessionmaker[Session]
|async_sessionmaker[AsyncSession]
)
- class advanced_alchemy.config.common.SessionT¶
Type variable for a SQLAlchemy session.
See also
sqlalchemy.Session
sqlalchemy.ext.asyncio.AsyncSession
alias of TypeVar(‘SessionT’, bound=
Session
|AsyncSession
)