Maison >développement back-end >tutoriel php >Pourquoi mon instruction préparée par PHP PDO renvoie-t-elle une erreur « Numéro de paramètre invalide » ?
Erreur de numéro de paramètre non valide dans PHP PDO
Lorsque vous essayez d'exécuter une instruction préparée à l'aide de PDO, vous pouvez rencontrer l'erreur "SQLSTATE[HY093 ] : Numéro de paramètre invalide." Ce problème est dû à une utilisation incorrecte des marqueurs de paramètres.
La fonction fournie add_persist utilise l'instruction préparée suivante :
INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash
Lors de la liaison des valeurs des paramètres à l'aide de la méthodeexecute(), la fonction utilise les valeurs suivantes :
["user_id" => $user_id, "hash" => $hash, "expire" => $future]
Cependant, l'instruction préparée contient un marqueur de paramètre en double pour le hachage, ce qui n'est pas autorisé par PDO. Pour résoudre ce problème, nous devons attribuer un marqueur de paramètre unique pour chaque valeur transmise.
Le code corrigé serait :
$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2"; $stm = $db->prepare($sql); $stm->execute( array("user_id" => $user_id, "hash" => $hash, "expire" => $future, "hash2" => $hash) );
Le paramètre supplémentaire :hash2 garantit qu'il n'y a pas dupliquez les marqueurs de paramètres dans l'instruction préparée, résolvant ainsi l'erreur.
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!