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 :

Syntaxe pour faire un update dans un foreach [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ebeniste
    Inscrit en
    Décembre 2013
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ebeniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2013
    Messages : 30
    Par défaut Syntaxe pour faire un update dans un foreach
    Bonjour,
    j'ai un problème de syntaxe pour exécuter une requête update dans un foreach :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    foreach ($tabFormCustomer as $entry => $key) {
     
    //        var_dump($entry);
    //        var_dump($key );
     
            $reponse_Updatecustomer = database::getDB()->fct_updatePrepare(
                "update customer_nfo
                left join stay_nfo on  idcustomer=post_id
                set
                '".$entry."' = '".$key."'
                where idstays_nfo = '".$get_CustomerID."' ");
        }
    ça coince au niveau du :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    '".$entry."' = '".$key."'
    Si je rentre en dur comme par exemple : cela fonctionne parfaitement, la requête update s'exécute.

    Pour les deux variables, le vardump donne cela (extrait..)
    \src\BO\BO_view\updateCustomer_view.php:87:string 'ch_origin' (length=9)
    \src\BO\BO_view\updateCustomer_view.php:88:string 'Airbnb' (length=6)
    \src\BO\BO_view\updateCustomer_view.php:87:string 'ch_civility' (length=11)
    \src\BO\BO_view\updateCustomer_view.php:88:string '2' (length=1)
    \src\BO\BO_view\updateCustomer_view.php:87:string 'ch_first_name' (length=13)
    \src\BO\BO_view\updateCustomer_view.php:88:string 'Alexandra' (length=9)


    Merci d'avance

  2. #2
    Membre Expert Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Par défaut
    Bonjour danamaro,

    En passant ...
    Et en enlevant les simple quotes autour de $entry ça donne quoi ?
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $reponse_Updatecustomer = database::getDB()->fct_updatePrepare(
                "update customer_nfo
                left join stay_nfo on  idcustomer=post_id
                set
                ".$entry." = '".$key."'
                where idstays_nfo = '".$get_CustomerID."' ");

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    A quoi ressemble la fonction fct_updatePrepare() ?

    Parce que là, tu NE prépare RIEN du tout !

  4. #4
    Membre averti
    Homme Profil pro
    Ebeniste
    Inscrit en
    Décembre 2013
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ebeniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2013
    Messages : 30
    Par défaut
    Citation Envoyé par jreaux62 Voir le message
    Bonjour,

    A quoi ressemble la fonction fct_updatePrepare() ?

    Parce que là, tu NE prépare RIEN du tout !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public function fct_updatePrepare($statement) {
     
            $res = $this->getPDO()->prepare($statement);
            $res->execute();
        }
    Cela fonctionne très bien si je rentre par exemple : mais avec les variables $entry et $key je n'arrive pas à trouver la bonne syntaxe

  5. #5
    Membre averti
    Homme Profil pro
    Ebeniste
    Inscrit en
    Décembre 2013
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ebeniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2013
    Messages : 30
    Par défaut
    J'ai fait quelques tests supplémentaires, et avec ça fonctionne !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    foreach ($tabFormCustomer as $entry => $key) {
     
    //        var_dump($entry);
    //        var_dump($key );
            $tutu = "toto";
     
            $reponse_Updatecustomer = database::getDB()->fct_updatePrepare(
                "update customer_nfo
                left join stay_nfo on  idcustomer=post_id
                set
                ch_country = '".$tutu."'
                where idstays_nfo = '".$get_CustomerID."' ");
        }

  6. #6
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    1- Le problème n'est pas que "ça fonctionne ou pas" : le problème c'est que ce N'est PAS une requête préparée !

    2- Voici à quoi devrait ressembler une VRAI requête préparée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public function fct_updatePrepare($statement, $params=[]) {
     
            $res = $this->getPDO()->prepare($statement);
            $res->execute($params);
    }
    Et l'appel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $reponse_Updatecustomer = database::getDB()->fct_updatePrepare(
                "update customer_nfo
                left join stay_nfo on  idcustomer=post_id
                set
                ".$entry." = ?
                where idstays_nfo = ? ",
    			[$key, $get_CustomerID]
    			);
    Encore faut-il que $entry n'amène pas de risque d'injection SQL !
    -> il faudrait s'assurer qu'il correspond bien au nom d'une colonne de la table SQL

  7. #7
    Membre averti
    Homme Profil pro
    Ebeniste
    Inscrit en
    Décembre 2013
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ebeniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2013
    Messages : 30
    Par défaut
    Un grand merci, c'est tout à fait ça.
    j'ai complètement zappé cette partie. Je vais creuser la question sur le problème de $entry.

    Merci,

  8. #8
    Membre averti
    Homme Profil pro
    Ebeniste
    Inscrit en
    Décembre 2013
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ebeniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Décembre 2013
    Messages : 30
    Par défaut
    Citation Envoyé par vttman Voir le message
    Bonjour danamaro,

    En passant ...
    Et en enlevant les simple quotes autour de $entry ça donne quoi ?
    =>
    cela ne donne rien, désolé

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

Discussions similaires

  1. Que faut il utiliser pour faire des recherches dans LDAP?
    Par kabouns dans le forum API standards et tierces
    Réponses: 5
    Dernier message: 04/08/2006, 15h24
  2. [MySQL] problème pour faire un update
    Par ph_anrys dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 16/03/2006, 15h48
  3. Réponses: 4
    Dernier message: 09/02/2006, 15h20
  4. Probleme pour faire une somme dans header ??
    Par snoop57 dans le forum Access
    Réponses: 7
    Dernier message: 01/12/2005, 13h40
  5. Réponses: 7
    Dernier message: 26/07/2005, 16h41

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