Partage
  • Partager sur Facebook
  • Partager sur Twitter

Erreur SQLSTATE[HY093]

Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter

Sujet résolu
    1 février 2024 à 19:00:22

    Bonjour, je suis débutant, et j'essaie de relié ma BDD à mon formulaire PHP d'inscription, mais je suis bloqué par cette erreur, la voici en entier :"Fatal error: Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in E:\XAMPP\htdocs\tests\submit_inscription.php:26 Stack trace: #0 E:\XAMPP\htdocs\tests\submit_inscription.php(26): PDOStatement->execute(Array) #1 {main} thrown in E:\XAMPP\htdocs\tests\submit_inscription.php on line 26"

    J'ai essayé plusieurs solutions en regardant sur des forums qui avait la même erreur que moi sans succès, quelqu'un aurait une idée ? 

    voici le code de ma page : 

    <?php
    $servername = "localhost";
    $username = "root";
    $password = "";
    
    try{
    $bdd = newPDO("mysql:host=$servername;dbname=lfl_fan", $username, $password);
    $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    echo"connexion réussie !";
    }
    catch(PDOExeption$e){
    echo"Erreur : ".$e->getMessage();
    }
    
    if(isset($_POST['ok'])){
    $pseudonyme = $_POST['pseudonyme'];
    $nom = $_POST ['nom'];
    $prenom = $_POST['prenom'];
    $email = $_POST['email'];
    $pass = $_POST['pass'];
    
    $requete = $bdd->prepare("INSERT INTO users VALUES (0, :pseudonyme, :nom, :prenom, :email, pass)");
    $requete ->execute(
    array(
    "pseudonyme" => $pseudonyme,
    "nom" => $nom,
    "prenom" => $prenom,
    "email" => $email,
    "pass" => $pass,
            )
            );
    $response = $requete->fetchAll(PDO::FETCH_ASSOC);
    var_dump($reponse);
    }
    ?>
    


    -
    Edité par Silverhand 2 février 2024 à 16:47:08

    • Partager sur Facebook
    • Partager sur Twitter
      1 février 2024 à 19:19:44

      Bonjour, Merci de lire les règles du forum AVANT de créer un sujet. Modifier votre titre pour un titre descriptif de votre problématique.

      Le message qui suit est une réponse automatique activée par un membre de l'équipe de modération. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code </>

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton  </> de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: php;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Mauvais titre

      Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

      Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

      De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

      Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

      Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

      (titre originel : Erreur)

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter
        2 février 2024 à 0:19:25

        Hello,

        Regarde bien la requête dans le prepare. Il te manque quelque chose.

        • Partager sur Facebook
        • Partager sur Twitter
          2 février 2024 à 16:27:13

          Merci Quenti77 pour ta réponse, j'ai eu beau cherchez, je n'ai pas trouvé l'élément manquant,

          mais je me suis renseigné et j'ai découvert la fonction "bindParam" qui m'a permis de résoudre le problème.

          Cela fonctionne maintenant, voici la nouvelle requête prepare : 

              $requete = $bdd->prepare("INSERT INTO users VALUES (0, :pseudonyme, :nom, :prenom, :email, :pass)");
          
          $requete->bindParam(":pseudonyme", $pseudonyme);
          $requete->bindParam(":nom", $nom);
          $requete->bindParam(":prenom", $prenom);
          $requete->bindParam(":email", $email);
          $requete->bindParam(":pass", $pass);
          
          $requete->execute();
          
                  $response = $requete->fetchAll(PDO::FETCH_ASSOC);
                  var_dump($response);
          }
          ?>

          -
          Edité par Silverhand 2 février 2024 à 16:27:45

          • Partager sur Facebook
          • Partager sur Twitter
            2 février 2024 à 16:29:50

            Bonjour,

            merci de suivre également les demandes de mon camarade AbcAbc6 concernant le titre (« Erreur » c'est bien trop vague) et le code.

            • Partager sur Facebook
            • Partager sur Twitter

            Pas d'aide concernant le code par MP, le forum est là pour ça :)

              2 février 2024 à 17:41:52

              D'accord, merci pour votre retour ! 

              Lamecarlate a écrit:

              Bonjour,

              merci de suivre également les demandes de mon camarade AbcAbc6 concernant le titre (« Erreur » c'est bien trop vague) et le code.



              -
              Edité par Silverhand 2 février 2024 à 17:42:21

              • Partager sur Facebook
              • Partager sur Twitter
                3 février 2024 à 9:41:32

                Du coup, je te conseil de comparer la ligne 1 de ton nouveau code avec la ligne 22 de ton ancien code. Il y a une différence minim vers la fin de la ligne.
                • Partager sur Facebook
                • Partager sur Twitter
                  6 février 2024 à 17:07:59

                  effectivement ! maintenant je le vois ! :)

                  Merci !

                  quenti77 a écrit:

                  Du coup, je te conseil de comparer la ligne 1 de ton nouveau code avec la ligne 22 de ton ancien code. Il y a une différence minim vers la fin de la ligne.



                  • Partager sur Facebook
                  • Partager sur Twitter
                    6 février 2024 à 19:09:23

                    Si tout est ok pour toi tu peux mettre en résolu ton sujet :)
                    • Partager sur Facebook
                    • Partager sur Twitter

                    Erreur SQLSTATE[HY093]

                    × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
                    • Editeur
                    • Markdown