使用PDO运行多个查询时如何出错?

时间:2014-04-23 14:35:09

标签: php mysql pdo

我正在使用PDO运行多个查询。如果第二个查询失败,则抛出异常。

$db = new PDO("mysql:host=localhost;dbname=test", 'root', '');
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$sql = "
DELETE FROM car; 
INSERT INTO car(name, type) SELECT name, from FROM vehicle;
";

try {
    $db->exec($sql);
}
catch (PDOException $e)
{
    echo $e->getMessage();
    die();
}

执行上述代码时不会抛出异常。

如何确保所有查询都成功运行?如何查看哪些查询失败?

P.S。我正在使用PDO多查询来运行MySQL转储,但任何有效的.sql文件都应该有效。

3 个答案:

答案 0 :(得分:7)

我在使用准备好的声明时找到了答案。循环遍历所有行集后,我可以使用$stmt->errorInfo()检查上次执行的查询是否导致错误。

$db = new PDO("mysql:host=localhost;dbname=test", 'root', '');
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT);
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1);

$sql = "
DELETE FROM car; 
INSERT INTO car(name, type) SELECT name, from FROM vehicle;
";

$stmt = $db->prepare($sql);
$stmt->execute();
$i = 0;

do {
  $i++;
} while ($stmt->nextRowset());

$error = $stmt->errorInfo();
if ($error[0] != "00000") {
  echo "Query $i failed: " . $error[2];
  die();
}

答案 1 :(得分:1)

以下代码将说明如何在运行多个查询时捕获错误。尽量避免使用" DELIMITER //"。查询通常分别由";"。

组成
<?php
// Create SQL List
$sqlStatements = "SELECT 100;SELECT 200;SELECT 300; Error SELECT 400;SELECT 500;";

// Prepare and execute statements
$options = [\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION];
$db = new PDO("mysql:host=127.0.0.1;dbname=test", 'root', '', $options);

// Prepare and execute
$error = false;
$statement = $db->prepare($sqlStatements);
$statement->execute();

// Check error
try{
    do{
        // Print Resultset
        $rowset = $statement->fetchAll(PDO::FETCH_NUM);
        var_dump($rowset);
    }while($statement->nextRowset());

}catch(\Exception $e){
    echo $e->getMessage()."\n";
}
?>

答案 2 :(得分:0)

没有明确和简单的方法可以做到这一点。

我认为,最好的方法是逐个查询读取转储文件并一次执行一个查询。

如果DB驱动程序告诉它,您也可以解析错误消息并提取问题行号(例如&#39;未知标识符&#39; blabla&#39; 在第666行&#39;)