What's the best way of capturing any DBI errors in Perl? For example if an insert fails because there were illegal characters in the values being inserted, how can I not have the script fail, but capture the error and handle it appropriately.
I don't want to do the "or die" because I don't want to stop execution of the script.
Use the
RaiseError=>1
configuration inDBI->connect
, and wrap your calls to the$dbh
and$sth
in a try block (TryCatch and Try::Tiny are good implementations for try blocks).See the docs for more information on other connect variables available.
for example:
you can also do the following, which will allow you to die, or gracefully handle the errors and continue.