Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment puis-je obtenir une erreur lors de l'exécution de plusieurs requêtes avec PDO ?

J'ai trouvé la réponse en utilisant une déclaration préparée. Après avoir parcouru tous les ensembles de lignes, je peux vérifier si la dernière requête exécutée a provoqué une erreur en utilisant $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();
}