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 :

PDO, INSERT: Erreur que je ne m'explique pas [MySQL]


Sujet :

PHP & Base de données

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 718
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 718
    Par défaut PDO, INSERT: Erreur que je ne m'explique pas
    Bonjour à tous,

    J'ai la fonction suivante:
    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
    16
    17
    function insertAddress(array $data): false|string
    {
    	$db = dbConnect();
    	var_dump($data);
    	extract($data);
    	//exit;
     
    $sql = <<<SQL
    INSERT IGNORE INTO dat_addresses
    ('id_user', 'address', 'country', 'zipcode', 'locality' ,'homephone')
    VALUES(':id_user', ':address', ':country', ':zipcode', ':locality', ':homephone') 
    SQL;
    	$array = [':id_user'=>$id_user, ':address'=>$address, ':country'=>$country, ':zipcode'=>$zipcode, ':locality'=>$locality, ':homephone'=>$homephone, ];
    	$stmt = $db->prepare($sql);
    	$stmt->execute($array);
    	return $db->lastInsertId();
    }
    Cette fonction provoque l'erreur suivante:
    Uncaught PDOException: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens
    avec cette indication en dernière ligne de la pile "call stack"
    execute( $params = [':address' => '', ':country' => 'AL', ':zipcode' => '', ':locality' => '', ':homephone' => ''] )
    or si je regarde bien ma fonction, j'ai bien 5 éléments bien orthographiés dans la requête et dans les paramètres.
    L'image ci-dessous donne la structure de la table selon PhpMyAdmin:
    Nom : Sans titre.png
Affichages : 111
Taille : 6,6 Ko
    Images attachées Images attachées

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 07/05/2018, 13h41
  2. [MySQL] PDO insert into depuis un formulaire n'ecrit pas dans ma bdd
    Par petinico83 dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 30/12/2013, 17h51
  3. Réponses: 5
    Dernier message: 22/03/2008, 11h24
  4. [PostGreSQL] une erreur que je ne comprends pas
    Par flo78 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 02/02/2006, 10h18
  5. erreur que j ai pas comprise ds mon pg informix
    Par zineb dans le forum Informix
    Réponses: 2
    Dernier message: 16/07/2003, 13h53

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