The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

DBIx::ParseError::MySQL - Error parser for MySQL

VERSION

version v1.0.3

SYNOPSIS

    use DBIx::ParseError::MySQL;

    eval {
        my $result = $dbh->do('SELECT 1');
    };
    if ($@) {
        if (DBIx::ParseError::MySQL->new($@)->is_transient) { $dbh->reconnect }
        else                                                { die; }
    }

DESCRIPTION

This module is a database error categorizer, specifically for MySQL. This module is also compatible with Galera's WSREP errors.

ATTRIBUTES

orig_error

Returns the original, untouched error object or string.

error_string

Returns the stringified version of the error.

error_type

Returns a string that describes the type of error. These can be one of the following:

    lock             Lock errors, like a lock wait timeout or deadlock
    connection       Connection/packet failures, disconnections
    shutdown         Errors that happen when a server is shutting down
    duplicate_value  Duplicate entry errors
    unknown          Any other error

is_transient

Returns a true value if the error is the type that is likely transient. For example, errors that recommend retrying transactions or connection failures. This check can be used to figure out if it's worth retrying a transaction.

This is merely a check for the following error types: lock connection shutdown.

CONSTRUCTORS

new

    my $parsed_error = DBIx::ParseError::MySQL->new($@);

Returns a DBIx::ParseError::MySQL object. Since the error is the only parameter, it can be passed by itself.

SEE ALSO

DBIx::Class::ParseError - A similar parser, but specifically tailored to DBIx::Class.

AUTHOR

Grant Street Group <developers@grantstreet.com>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2020 - 2023 by Grant Street Group.

This is free software, licensed under:

  The Artistic License 2.0 (GPL Compatible)