Perl DBI – 捕获错误

在Perl中捕获任何DBI错误的最佳方法是什么?例如,如果插入失败,因为插入的值中存在非法字符,我怎么能不让脚本失败,而是捕获错误并适当地处理它.

我不想做“或死”,因为我不想停止执行脚本.

解决方法

在DBI-> connect中使用RaiseError => 1配置,并在try块中包含对$dbh和$sth的调用( TryCatchTry::Tiny是try块的良好实现).

有关其他可用连接变量的更多信息,请参见the docs.

例如:

use strict;
use warnings;

use DBI;
use Try::Tiny;

my $dbh = DBI->connect(
    $your_dsn_here,$user,$password,{
        PrintError => 0,PrintWarn  => 1,RaiseError => 1,AutoCommit => 1,}
);
try
{
    # deliberate typo in query here
    my $data = $dbh->selectall_arrayref('SOHW TABLES',{});
}
catch
{
    warn "got dbi error: $_";
};

相关文章

忍不住在 PerlChina 邮件列表中盘点了一下 Perl 里的 Web 应用框架(巧的是 PerlBuzz 最近也有一篇相关...
bless有两个参数:对象的引用、类的名称。 类的名称是一个字符串,代表了类的类型信息,这是理解bless的...
gb2312转Utf的方法: use Encode; my $str = "中文"; $str_cnsoftware = encode("utf-8...
  perl 计算硬盘利用率, 以%来查看硬盘资源是否存在IO消耗cpu资源情况; 部份代码参考了iostat源码;...
1 简单变量 Perl 的 Hello World 是怎么写的呢?请看下面的程序: #!/usr/bin/perl print "Hello W...
本文介绍Perl的Perl的简单语法,包括基本输入输出、分支循环控制结构、函数、常用系统调用和文件操作,...