IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Erreur execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables [PDO]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut Erreur execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables
    Bonjour, je souhaite introduire les donnés dans ma base de donné mysql mais j'ai l'erreur suivante lorsque j'exécute ma page:

    SCREAM: Error suppression ignored for
    ( ! ) Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens in C:\wamp\www\Test\verification.php on line 67
    Je vous donne la partie du code ou est l'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    $reponse = $bdd->prepare('INSERT INTO membres(nom, prenom, age, adresse, numero, commune, codepostal, numfix, gsm, pseudo, email, motDePasse, reglement) 
    		VALUES (:nom, :prenom, :age, :adresse, :numero, :commune, :codepostal, :numfix, :gsm, :pseudo, :email, :motDePasse, :reglement)');
    		$reponse->execute(array(
    		'nom' => $nom,
    		'prenom' => $prenom,
    		'age' => $age,
    		'adresse' => $adresse,
    		'numero' => $numero,
    		'commune' => $commune,
    		'codepostal' => $codepostal,
    		'numfixe' => $numfixe,
    		'gsm' => $gsm,
    		'pseudo' => $pseudo,
    		'email' => $email,
    		'mdp' => $motDePasse));
    J'ai vérifié si j'ai pas oublié une virgule, parenthese ou quoi mais je ne pense pas que ca soit l'erreur. Les entrées de mon array doivent elles être dans le même ordre que dans ma base de donné ?

    Merci pour l'aide.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu as mis "motDePasse" au lieu de "mdp" et tu n'as pas mis "reglement"
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut
    Dans ma base de donné l'entré pour le mot de passe est mdp et non motDePasse et pour reglement je suis obliger de le mettre ?

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    l'entré pour le mot de passe est mdp et non motDePasse
    C'est toi qui a mis "motDePasse" ce n'est pas moi.
    et pour reglement je suis obliger de le mettre ?
    S'il a une valeur par défaut dans la définition de ta table, non.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut
    Dans ma table le nom est mdp est la nom de ma variable est motDePasse donc je ne comprend pas ce que tu veux dire. Pour l'entrée reglement, je n'ai pas de valeur prédéfinie mais "reglement' => $reglement)" est correcte non ? (Sans les guillemets bien sûr)

    Si cest 2 écritures sont correctes, le problème est toujours présent, je continue de chercher

    EDIT: J'ai compris ce que tu voulais dire avec mon mot de passe

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Pour faire simple : tu dois avoir la même chose dans le "prepare" est dans le "execute".

    - si ton paramètre s'apelle ":motDePasse" dans le prepare, il doit s'appeller ":motDePasse" dans le execute.
    - si tu as un paramètre ":reglement" dans le prepare, tu dois avoir un paramètre ":reglement" dans le execute.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut
    - si ton paramètre s'apelle ":motDePasse" dans le prepare, il doit s'appeller ":motDePasse" dans le execute.
    Et il doit avoir avoir le même nom que mon entré dans ma base de donné (mdp) ou de mon paramère (motDePasse) ou ca ne change rien tant que les noms sont les mêmes ?

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Le nom du paramètre est celui que tu veux.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut
    Mh ok, le problème persiste :s

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Donne nous ton code corrigé.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Septembre 2013
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Bahamas

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Septembre 2013
    Messages : 57
    Points : 35
    Points
    35
    Par défaut
    J'ai trouvé le problème, il vient de numfixe ou j'avais oublié un "e" ... Merci quand même pour vos réponses

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Erreur : SQLSTATE[HY093]: Invalid parameter number
    Par antoinv10 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 16/06/2015, 15h39
  2. Réponses: 2
    Dernier message: 30/05/2015, 19h47
  3. Réponses: 3
    Dernier message: 22/05/2013, 13h06
  4. Réponses: 6
    Dernier message: 27/10/2011, 13h27
  5. Réponses: 3
    Dernier message: 25/08/2009, 23h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo