我正在使用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文件都应该有效。
答案 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;)