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=>1configuration inDBI->connect, and wrap your calls to the$dbhand$sthin 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: