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 :

Requête dynamique avec passage de paramètres


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    IT Développeur
    Inscrit en
    Mars 2009
    Messages
    274
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : IT Développeur

    Informations forums :
    Inscription : Mars 2009
    Messages : 274
    Par défaut Requête dynamique avec passage de paramètres
    Bonjour j'essaie de faire une requête dynamique INSERT avec passage de paramètres.

    Voici mon code
    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
     
    $params = [];
    $query = "INSERT INTO ".$this->table." (";
                   foreach ($data as $key => $value) {
                          $query .= "".strtolower($key).", ";
                   }
                   $query = substr($query, 0, -2); // suppression de la dernière ","
                   $query .= ") VALUES (";
                   foreach ($data as $key => $value) {
                       $query .= ":".strtolower($key).", ";
                       $params[":".strtolower($key)]= $value;
                   }
                      $query = substr($query, 0, -2); // suppression de la dernière ","
                      $query .= ")";
     
                    $statement = $this->Instance()->prepare($query);
                    $statement->execute($params);
    Normalement execute accepte un tableau en paramètre. https://www.php.net/manual/fr/pdostatement.execute.php

    La connexion à la db et le nom de la table sont bons.
    Si j'exécute le query en complétant manuellement le tableau cela fonctionne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $statement->execute(array(':lastname'=>'Dupond', ':firstname'=>'Alphonse'));
    Quelqu'un a-t-il une explication?
    Merci

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 322
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 322
    Billets dans le blog
    17
    Par défaut
    Si tu affiches $query ça donne quoi ? $this->Instance()->errorInfo() ou $statement->errorInfo() donnent quelque chose ?

    Pour construire ta requête INSERT tu peux aussi viser la forme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO table
    SET field1 = value1, field2 = value2
    Plus simple à produire et à lire.

  3. #3
    Membre éclairé
    Profil pro
    IT Développeur
    Inscrit en
    Mars 2009
    Messages
    274
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : IT Développeur

    Informations forums :
    Inscription : Mars 2009
    Messages : 274
    Par défaut
    Merci pour ton aide.

    Voici le query généré et le tableau de paramètres générés dynamiquement:
    Nom : query.jpg
Affichages : 83
Taille : 101,8 Ko

    J'ai testé ce même query en construisant manuellement le tableau et cela fonctionne.
    Je viens également de tester si ce n'est pas le password encrypté qui pose problème mais non.
    Il semble que ce soit bien le password encrypté qui pose problème. Je vérifie.

    C'est visiblement le fait de générer le tableau dynamiquement qui pose problème.

  4. #4
    Membre éclairé
    Profil pro
    IT Développeur
    Inscrit en
    Mars 2009
    Messages
    274
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : IT Développeur

    Informations forums :
    Inscription : Mars 2009
    Messages : 274
    Par défaut
    Problème résolu.
    Erreur stupide... le varchar déclaré pour le password était trop court (24 caractères) alors qu'une fois encrypté il en fait 60.
    Merci pour l'aide.

  5. #5
    Expert confirmé Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 986
    Par défaut
    Quoi qu'il en soit, ça serait un peu moins laborieux comme ça:
    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
    18
    19
    $params = [
        'lastname' => 'Dupond',
        'firstname' => 'Alfred',
        'publicname' => 'Alfred Dupond',
        'mail' => 'da@gmail.com',
        'login' => 'da',
        'password' => '$2y$10$cyTuu1s0aWstOEefxeoD2ezUC1FtioVMrUNUjQ0sdZ11n5k5ncTgi',
        'iduseraccounttype' => 1,
        'iduseraccountstatus' => 2
    ];
     
     
    $columns = implode(', ', array_keys($params));
    $placeholders = ':' . implode(', :', array_keys($params));
     
    $query = "INSERT INTO {$this->table} ($columns) VALUES ($placeholders)";
     
    $statement = $this->Instance()->prepare($query);
    $statement->execute($params);

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

Discussions similaires

  1. [Calendrier] Dynamique avec passage de date en paramètre
    Par hannibal974 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 10
    Dernier message: 22/05/2014, 02h26
  2. Réponses: 0
    Dernier message: 25/07/2007, 17h17
  3. Fonction ouvre avec passage de paramètres
    Par nath-0-0 dans le forum WinDev
    Réponses: 4
    Dernier message: 20/11/2006, 12h51
  4. [Système] Appel d'un exe avec passage de paramètres
    Par licorne dans le forum Langage
    Réponses: 2
    Dernier message: 04/05/2006, 12h57
  5. Requête de sélection : Passage de paramètre ...
    Par snoopy69 dans le forum Access
    Réponses: 2
    Dernier message: 28/03/2006, 10h58

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