Trait sqlx_core::error::DatabaseError

source ·
pub trait DatabaseError: 'static + Send + Sync + StdError {
    // Required methods
    fn message(&self) -> &str;
    fn kind(&self) -> ErrorKind;

    // Provided methods
    fn code(&self) -> Option<Cow<'_, str>> { ... }
    fn constraint(&self) -> Option<&str> { ... }
    fn table(&self) -> Option<&str> { ... }
    fn is_unique_violation(&self) -> bool { ... }
    fn is_foreign_key_violation(&self) -> bool { ... }
    fn is_check_violation(&self) -> bool { ... }
}
Expand description

An error that was returned from the database.

Required Methods§

source

fn message(&self) -> &str

The primary, human-readable error message.

source

fn kind(&self) -> ErrorKind

Returns the kind of the error, if supported.

§Note

Not all back-ends behave the same when reporting the error code.

Provided Methods§

source

fn code(&self) -> Option<Cow<'_, str>>

The (SQLSTATE) code for the error.

source

fn constraint(&self) -> Option<&str>

Returns the name of the constraint that triggered the error, if applicable. If the error was caused by a conflict of a unique index, this will be the index name.

§Note

Currently only populated by the Postgres driver.

source

fn table(&self) -> Option<&str>

Returns the name of the table that was affected by the error, if applicable.

§Note

Currently only populated by the Postgres driver.

source

fn is_unique_violation(&self) -> bool

Returns whether the error kind is a violation of a unique/primary key constraint.

source

fn is_foreign_key_violation(&self) -> bool

Returns whether the error kind is a violation of a foreign key.

source

fn is_check_violation(&self) -> bool

Returns whether the error kind is a violation of a check.

Implementations§

source§

impl dyn DatabaseError

source

pub fn downcast_ref<E: DatabaseError>(&self) -> &E

Downcast a reference to this generic database error to a specific database error type.

§Panics

Panics if the database error type is not E. This is a deliberate contrast from Error::downcast_ref which returns Option<&E>. In normal usage, you should know the specific error type. In other cases, use try_downcast_ref.

source

pub fn downcast<E: DatabaseError>(self: Box<Self>) -> Box<E>

Downcast this generic database error to a specific database error type.

§Panics

Panics if the database error type is not E. This is a deliberate contrast from Error::downcast which returns Option<E>. In normal usage, you should know the specific error type. In other cases, use try_downcast.

source

pub fn try_downcast_ref<E: DatabaseError>(&self) -> Option<&E>

Downcast a reference to this generic database error to a specific database error type.

source

pub fn try_downcast<E: DatabaseError>( self: Box<Self>, ) -> Result<Box<E>, Box<Self>>

Downcast this generic database error to a specific database error type.

Trait Implementations§

source§

impl Error for Box<dyn DatabaseError>

1.30.0 · source§

fn source(&self) -> Option<&(dyn Error + 'static)>

The lower-level source of this error, if any. Read more
1.0.0 · source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type based access to context intended for error reports. Read more

Implementors§