Maison > Article > développement back-end > Pourquoi est-ce que j'obtiens une erreur « SQLSTATE[HY093] : numéro de paramètre invalide » dans mon code PHP PDO ?
Lors de la tentative d'exécution de la fonction add_persist, les développeurs peuvent rencontrer l'erreur "SQLSTATE[HY093] : numéro de paramètre non valide." Cette erreur provient d'une liaison de paramètre incorrecte dans la requête SQL.
Dans le code fourni, l'instruction $sql tente de mettre à jour une ligne de la table persistante en exécutant les commandes INSERT et ON DUPLICATE KEY UPDATE. Cependant, il existe une différence dans les liaisons de paramètres dans l'appel $stm->execute. Plus précisément, le paramètre :hash apparaît deux fois, mais selon la documentation PDO, chaque marqueur de paramètre unique ne doit être lié qu'une seule fois à une valeur.
Pour résoudre ce problème, la requête $sql doit être modifiée pour inclure un marqueur de paramètre pour chaque valeur transmise, comme suit :
$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2";
De plus, l'appel $stm->execute doit inclure des liaisons pour :hash et :hash2 paramètres :
$stm->execute( array(":user_id" => $user_id, ":hash" => $hash, ":expire" => $future, ":hash2" => $hash) );
En résolvant ce problème de liaison de paramètre, la fonction add_persist exécutera correctement la requête SQL sans déclencher l'erreur « Numéro de paramètre invalide ».
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!