【问题标题】:Can't handle SQL exception with try-catch [duplicate]无法使用 try-catch 处理 SQL 异常 [重复]
【发布时间】:2014-01-18 22:48:19
【问题描述】:

我正在创建相当大的导入脚本。我想查看任何有问题的(未执行的)SQL 查询。我在使用 try-catch PHP 块捕获错误的 SQL 查询时遇到问题。

我有一个问题:

SELECT id FROM tag WHERE name IN ()

当然有一个错误,所以我想用这段代码打印这样的查询:

$sql = "SELECT id FROM tag WHERE name ".$tagsSql."";

try
{
    $query = mysqli_query($this->mysqli, $sql);
    $result = $query->fetch_assoc();
}
catch(Exception $e)
{
    echo 'Problem with: '.$sql;
    print_r($e); die;
}

运行脚本时,PHP 会抛出这个:

Fatal error: Call to a member function fetch_assoc() on a non-object in C:\www\blackboard-import\index.php on line 227

为什么没有捕捉到这个错误?因为它是致命的?我该如何处理这种情况? 我使用mysqli来联系MySQL。

【问题讨论】:

    标签: php mysql sql mysqli try-catch


    【解决方案1】:

    这不是常规异常,而是致命错误(导致 PHP 关闭)。 mysqli_query() 将在错误时返回 false,这就是您当前脚本失败的原因,因此解决方案可能类似于以下内容

    try {
        $query = $this->msqli->query($sql);
        if ($query === FALSE) {
            throw new Exception($this->mysqli->error);
        }
    
        $result = $query->fetch_assoc();
    } catch(Exception $e) {
        //...
    }
    

    【讨论】:

      猜你喜欢
      • 2017-03-04
      • 2018-06-24
      • 1970-01-01
      • 1970-01-01
      • 2023-03-08
      • 2011-04-01
      • 1970-01-01
      • 1970-01-01
      • 2020-04-02
      相关资源
      最近更新 更多