Maison >base de données >tutoriel mysql >Pourquoi l'utilisation du même paramètre nommé deux fois dans une requête PDO INSERT...ON DUPLICATE KEY UPDATE provoque-t-elle une erreur « Numéro de paramètre non valide » ?
PHP PDOException : numéro de paramètre non valide
Problème :
Lors de la construction d'une requête INSERT avec une clause ON DUPLICATE KEY UPDATE, utilisant deux fois un marqueur de paramètre nommé dans la méthodeexecute() peut conduire à l'erreur Erreur « SQLSTATE[HY093] : Numéro de paramètre non valide ».
Solution :
Pour résoudre ce problème, attribuez différents marqueurs de paramètre pour chaque valeur dans la méthodeexecute() . Voici le code mis à jour :
$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2"; $stm->execute( array(":user_id" => $user_id, ":hash" => $hash, ":expire" => $future, ":hash2" => $hash) );
Explication :
La documentation PDO indique que "Vous ne pouvez pas utiliser deux fois un marqueur de paramètre nommé du même nom dans une instruction préparée ". En effet, chaque valeur transmise à la requête doit avoir un marqueur de paramètre unique. En attribuant différents marqueurs de paramètres pour la valeur de hachage mise à jour (:hash2), le problème est résolu.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!