Core Exceptions

Exceptions used with SQLAlchemy.

Die Basis-Exception-Klasse ist SQLAlchemyError. Exceptions, die als Ergebnis von DBAPI-Exceptions ausgelöst werden, sind alle Unterklassen von DBAPIError.

exception sqlalchemy.exc.AmbiguousForeignKeysError

Raised when more than one foreign key matching can be located between two selectables during a join.

exception sqlalchemy.exc.ArgumentError

Raised when an invalid or conflicting function argument is supplied.

This error generally corresponds to construction time state errors.

exception sqlalchemy.exc.AwaitRequired

Error raised by the async greenlet spawn if no async operation was awaited when it required one.

exception sqlalchemy.exc.Base20DeprecationWarning

Issued for usage of APIs specifically deprecated or legacy in SQLAlchemy 2.0.

attribute sqlalchemy.exc.Base20DeprecationWarning.deprecated_since: str | None = '1.4'

Indicates the version that started raising this deprecation warning

exception sqlalchemy.exc.CircularDependencyError

Raised by topological sorts when a circular dependency is detected.

There are two scenarios where this error occurs

method sqlalchemy.exc.CircularDependencyError.__init__(message: str, cycles: Any, edges: Any, msg: str | None = None, code: str | None = None)
exception sqlalchemy.exc.CompileError

Raised when an error occurs during SQL compilation

exception sqlalchemy.exc.ConstraintColumnNotFoundError

raised when a constraint refers to a string column name that is not present in the table being constrained.

Neu in Version 2.0.

exception sqlalchemy.exc.DBAPIError

Raised when the execution of a database operation fails.

Wraps exceptions raised by the DB-API underlying the database operation. Driver-specific implementations of the standard DB-API exception types are wrapped by matching sub-types of SQLAlchemy’s DBAPIError when possible. DB-API’s Error type maps to DBAPIError in SQLAlchemy, otherwise the names are identical. Note that there is no guarantee that different DB-API implementations will raise the same exception type for any given error condition.

DBAPIError features StatementError.statement and StatementError.params attributes which supply context regarding the specifics of the statement which had an issue, for the typical case when the error was raised within the context of emitting a SQL statement.

The wrapped exception object is available in the StatementError.orig attribute. Its type and properties are DB-API implementation specific.

method sqlalchemy.exc.DBAPIError.__init__(statement: str | None, params: _AnyExecuteParams | None, orig: BaseException, hide_parameters: bool = False, connection_invalidated: bool = False, code: str | None = None, ismulti: bool | None = None)
exception sqlalchemy.exc.DataError

Wraps a DB-API DataError.

exception sqlalchemy.exc.DatabaseError

Wraps a DB-API DatabaseError.

exception sqlalchemy.exc.DisconnectionError

A disconnect is detected on a raw DB-API connection.

This error is raised and consumed internally by a connection pool. It can be raised by the PoolEvents.checkout() event so that the host pool forces a retry; the exception will be caught three times in a row before the pool gives up and raises InvalidRequestError regarding the connection attempt.

Objektname Beschreibung

DontWrapMixin

A mixin class which, when applied to a user-defined Exception class, will not be wrapped inside of StatementError if the error is emitted within the process of executing a statement.

HasDescriptionCode

helper which adds ‘code’ as an attribute and ‘_code_str’ as a method

class sqlalchemy.exc.DontWrapMixin

A mixin class which, when applied to a user-defined Exception class, will not be wrapped inside of StatementError if the error is emitted within the process of executing a statement.

Z. B.

from sqlalchemy.exc import DontWrapMixin


class MyCustomException(Exception, DontWrapMixin):
    pass


class MySpecialType(TypeDecorator):
    impl = String

    def process_bind_param(self, value, dialect):
        if value == "invalid":
            raise MyCustomException("invalid!")
exception sqlalchemy.exc.DuplicateColumnError

a Column is being added to a Table that would replace another Column, without appropriate parameters to allow this in place.

Neu ab Version 2.0.0b4.

class sqlalchemy.exc.HasDescriptionCode

helper which adds ‘code’ as an attribute and ‘_code_str’ as a method

exception sqlalchemy.exc.IdentifierError

Raised when a schema name is beyond the max character limit

exception sqlalchemy.exc.IllegalStateChangeError

An object that tracks state encountered an illegal state change of some kind.

Neu in Version 2.0.

exception sqlalchemy.exc.IntegrityError

Wraps a DB-API IntegrityError.

exception sqlalchemy.exc.InterfaceError

Wraps a DB-API InterfaceError.

exception sqlalchemy.exc.InternalError

Wraps a DB-API InternalError.

exception sqlalchemy.exc.InvalidRequestError

SQLAlchemy was asked to do something it can’t do.

This error generally corresponds to runtime state errors.

exception sqlalchemy.exc.InvalidatePoolError

Raised when the connection pool should invalidate all stale connections.

A subclass of DisconnectionError that indicates that the disconnect situation encountered on the connection probably means the entire pool should be invalidated, as the database has been restarted.

This exception will be handled otherwise the same way as DisconnectionError, allowing three attempts to reconnect before giving up.

Neu seit Version 1.2.

exception sqlalchemy.exc.LegacyAPIWarning

indicates an API that is in ‘legacy’ status, a long term deprecation.

exception sqlalchemy.exc.MissingGreenlet

Error raised by the async greenlet await_ if called while not inside the greenlet spawn context.

exception sqlalchemy.exc.MovedIn20Warning

Subtype of RemovedIn20Warning to indicate an API that moved only.

exception sqlalchemy.exc.MultipleResultsFound

A single database result was required but more than one were found.

Changed in version 1.4: This exception is now part of the sqlalchemy.exc module in Core, moved from the ORM. The symbol remains importable from sqlalchemy.orm.exc.

exception sqlalchemy.exc.NoForeignKeysError

Raised when no foreign keys can be located between two selectables during a join.

exception sqlalchemy.exc.NoInspectionAvailable

A subject passed to sqlalchemy.inspection.inspect() produced no context for inspection.

exception sqlalchemy.exc.NoReferenceError

Raised by ForeignKey to indicate a reference cannot be resolved.

exception sqlalchemy.exc.NoReferencedColumnError

Raised by ForeignKey when the referred Column cannot be located.

method sqlalchemy.exc.NoReferencedColumnError.__init__(message: str, tname: str, cname: str)
exception sqlalchemy.exc.NoReferencedTableError

Raised by ForeignKey when the referred Table cannot be located.

method sqlalchemy.exc.NoReferencedTableError.__init__(message: str, tname: str)
exception sqlalchemy.exc.NoResultFound

A database result was required but none was found.

Changed in version 1.4: This exception is now part of the sqlalchemy.exc module in Core, moved from the ORM. The symbol remains importable from sqlalchemy.orm.exc.

exception sqlalchemy.exc.NoSuchColumnError

A nonexistent column is requested from a Row.

Klassensignatur

class sqlalchemy.exc.NoSuchColumnError (sqlalchemy.exc.InvalidRequestError, builtins.KeyError)

exception sqlalchemy.exc.NoSuchModuleError

Raised when a dynamically-loaded module (usually a database dialect) of a particular name cannot be located.

exception sqlalchemy.exc.NoSuchTableError

Table does not exist or is not visible to a connection.

exception sqlalchemy.exc.NotSupportedError

Umschließt einen DB-API NotSupportedError.

exception sqlalchemy.exc.ObjectNotExecutableError

Ausgelöst, wenn ein Objekt an .execute() übergeben wird, das nicht als SQL ausgeführt werden kann.

method sqlalchemy.exc.ObjectNotExecutableError.__init__(target: Any)
exception sqlalchemy.exc.OperationalError

Umschließt einen DB-API OperationalError.

exception sqlalchemy.exc.PendingRollbackError

Eine Transaktion ist fehlgeschlagen und muss vor der Fortsetzung zurückgerollt werden.

Neu in Version 1.4.

exception sqlalchemy.exc.ProgrammingError

Umschließt einen DB-API ProgrammingError.

exception sqlalchemy.exc.ResourceClosedError

Eine Operation wurde von einer Verbindung, einem Cursor oder einem anderen Objekt angefordert, das sich in einem geschlossenen Zustand befindet.

exception sqlalchemy.exc.SADeprecationWarning

Ausgegeben für die Verwendung veralteter APIs.

Klassensignatur

class sqlalchemy.exc.SADeprecationWarning (sqlalchemy.exc.HasDescriptionCode, builtins.DeprecationWarning)

attribute sqlalchemy.exc.SADeprecationWarning.deprecated_since: str | None = None

Indicates the version that started raising this deprecation warning

exception sqlalchemy.exc.SAPendingDeprecationWarning

Eine ähnliche Warnung wie SADeprecationWarning, diese Warnung wird in modernen Versionen von SQLAlchemy nicht verwendet.

Klassensignatur

class sqlalchemy.exc.SAPendingDeprecationWarning (builtins.PendingDeprecationWarning)

attribute sqlalchemy.exc.SAPendingDeprecationWarning.deprecated_since: str | None = None

Indicates the version that started raising this deprecation warning

exception sqlalchemy.exc.SATestSuiteWarning

Warnung für eine Bedingung, die während Tests erkannt wurde und nicht-fatal ist

Derzeit außerhalb von SAWarning, damit wir mit Tools wie Alembic umgehen können, die Warnungen falsch verarbeiten.

Klassensignatur

class sqlalchemy.exc.SATestSuiteWarning (builtins.Warning)

exception sqlalchemy.exc.SAWarning

Zur Laufzeit ausgegeben.

Klassensignatur

class sqlalchemy.exc.SAWarning (sqlalchemy.exc.HasDescriptionCode, builtins.RuntimeWarning)

exception sqlalchemy.exc.SQLAlchemyError

Generische Fehlerklasse.

Klassensignatur

class sqlalchemy.exc.SQLAlchemyError (sqlalchemy.exc.HasDescriptionCode, builtins.Exception)

exception sqlalchemy.exc.StatementError

Ein Fehler ist während der Ausführung einer SQL-Anweisung aufgetreten.

StatementError umschließt die Ausnahme, die während der Ausführung ausgelöst wurde, und verfügt über die Attribute statement und params, die Kontext zu den Details der Anweisung liefern, die ein Problem hatte.

Das umschlossene Ausnahmeobjekt ist im Attribut orig verfügbar.

method sqlalchemy.exc.StatementError.__init__(message: str, statement: str | None, params: _AnyExecuteParams | None, orig: BaseException | None, hide_parameters: bool = False, code: str | None = None, ismulti: bool | None = None)
attribute sqlalchemy.exc.StatementError.ismulti: bool | None = None

multi-Parameter, der an repr_params() übergeben wird. None ist aussagekräftig.

attribute sqlalchemy.exc.StatementError.orig: BaseException | None = None

Die ursprüngliche Ausnahme, die ausgelöst wurde.

attribute sqlalchemy.exc.StatementError.params: _AnyExecuteParams | None = None

Die Parameterliste, die verwendet wurde, als dieser Fehler auftrat.

attribute sqlalchemy.exc.StatementError.statement: str | None = None

Die Zeichenkette der SQL-Anweisung, die beim Auftreten dieser Ausnahme aufgerufen wurde.

exception sqlalchemy.exc.TimeoutError

Ausgelöst, wenn ein Verbindungspool beim Abrufen einer Verbindung eine Zeitüberschreitung aufweist.

exception sqlalchemy.exc.UnboundExecutionError

SQL wurde versucht, ohne eine Datenbankverbindung zur Ausführung.

exception sqlalchemy.exc.UnreflectableTableError

Die Tabelle existiert, kann aber aus irgendeinem Grund nicht reflektiert werden.

Neu seit Version 1.2.

exception sqlalchemy.exc.UnsupportedCompilationError

Ausgelöst, wenn eine Operation vom angegebenen Compiler nicht unterstützt wird.

method sqlalchemy.exc.UnsupportedCompilationError.__init__(compiler: Compiled | TypeCompiler, element_type: Type[ClauseElement], message: str | None = None)