CockroachDB + AsyncPG¶
CockroachDB adapter using asyncpg with automatic transaction retry logic.
Configuration¶
- class sqlspec.adapters.cockroach_asyncpg.CockroachAsyncpgConfig[source]¶
Bases:
AsyncDatabaseConfig[PoolConnectionProxy,Pool,CockroachAsyncpgDriver]Configuration for CockroachDB using AsyncPG.
- driver_type¶
alias of
CockroachAsyncpgDriver
- connection_type¶
alias of
PoolConnectionProxy
- __init__(*, connection_config=None, connection_instance=None, migration_config=None, statement_config=None, driver_features=None, bind_key=None, extension_config=None, observability_config=None, **kwargs)[source]¶
- provide_session(*_args, statement_config=None, follower_reads=None, staleness=None, **_kwargs)[source]¶
Provide a database session context manager.
- Return type:
CockroachAsyncpgSessionContext
- get_signature_namespace()[source]¶
Get the signature namespace for this database configuration.
Returns a dictionary of type names to objects (classes, functions, or other callables) that should be registered with Litestar's signature namespace to prevent serialization attempts on database-specific structures.
Driver¶
- class sqlspec.adapters.cockroach_asyncpg.CockroachAsyncpgDriver[source]¶
Bases:
AsyncpgDriverCockroachDB AsyncPG driver with retry support.
- __init__(connection, statement_config=None, driver_features=None)[source]¶
Initialize driver adapter with connection and configuration.
- Parameters:
connection¶ (
PoolConnectionProxy) -- Database connection instancestatement_config¶ (
StatementConfig|None) -- Statement configuration for the driverdriver_features¶ (
dict[str, typing.Any] |None) -- Driver-specific features like extensions, secrets, and connection callbacksobservability¶ -- Optional runtime handling lifecycle hooks, observers, and spans
- async dispatch_execute(cursor, statement)[source]¶
Execute single SQL statement.
Handles both SELECT queries and non-SELECT operations.
- async dispatch_execute_many(cursor, statement)[source]¶
Execute SQL with multiple parameter sets using AsyncPG's executemany.
- async dispatch_execute_script(cursor, statement)[source]¶
Execute SQL script with statement splitting and parameter handling.
- handle_database_exceptions()[source]¶
Handle database exceptions with PostgreSQL error codes.
- Return type:
CockroachAsyncpgExceptionHandler
- property data_dictionary: CockroachAsyncpgDataDictionary¶
Get the data dictionary for this driver.
- Returns:
Data dictionary instance for metadata queries
Retry Configuration¶
- class sqlspec.adapters.cockroach_asyncpg.CockroachAsyncpgRetryConfig[source]¶
Bases:
objectCockroachDB asyncpg transaction retry configuration.
- classmethod from_features(driver_features)[source]¶
Build retry config from driver feature mappings.
- Return type:
- __init__(max_retries=10, base_delay_ms=50.0, max_delay_ms=5000.0, enable_logging=True)¶
Data Dictionary¶
- class sqlspec.adapters.cockroach_asyncpg.data_dictionary.CockroachAsyncpgDataDictionary[source]¶
Bases:
AsyncDataDictionaryBaseCockroachDB async data dictionary (AsyncPG).
- dialect: ClassVar[str] = 'cockroachdb'¶
Dialect identifier. Must be defined by subclasses as a class attribute.
- async get_version(driver)[source]¶
Get database version information.
- Parameters:
driver¶ (
CockroachAsyncpgDriver) -- Async database driver instance- Return type:
- Returns:
Version information or None if detection fails
- async get_feature_flag(driver, feature)[source]¶
Check if database supports a specific feature.
- Parameters:
driver¶ (
CockroachAsyncpgDriver) -- Async database driver instance
- Return type:
- Returns:
True if feature is supported, False otherwise
- async get_optimal_type(driver, type_category)[source]¶
Get optimal database type for a category.
- Parameters:
driver¶ (
CockroachAsyncpgDriver) -- Async database driver instancetype_category¶ (
str) -- Type category (e.g., 'json', 'uuid', 'boolean')
- Return type:
- Returns:
Database-specific type name
- async get_tables(driver, schema=None)[source]¶
Get list of tables in schema.
- Parameters:
driver¶ (
CockroachAsyncpgDriver) -- Async database driver instance
- Return type:
- Returns:
List of table metadata dictionaries
- async get_columns(driver, table=None, schema=None)[source]¶
Get column information for a table or schema.
- Parameters:
- Return type:
- Returns:
List of column metadata dictionaries
- async get_indexes(driver, table=None, schema=None)[source]¶
Get index information for a table or schema.
- Parameters:
- Return type:
- Returns:
List of index metadata dictionaries