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 :

[SQL] Requête UPDATE et tableau


Sujet :

PHP & Base de données

  1. #1
    Inscrit
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    531
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 531
    Points : 282
    Points
    282
    Par défaut [SQL] Requête UPDATE et tableau
    Bonjour,

    J'ai un formulaire avec une liste de textarea correspondant à des articles.

    Je fais des modifs dans chaque textarea, je clique sur valider et ça doit updater chaque article.

    Mais ça fonctionne pas.

    Je vous donne le code, si vous voulez bien jeter un coup d'oeil :

    FORMULAIRE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <input type="hidden" name="idArticle[]" value="'.$idArticle.'">
    <textarea cols="50" rows="20" name="contenu[]">'.stripslashes($article).'</textarea><p>
    REQUETE UPDATE :
    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
    20
    21
     
    <?php
    //si il y a la variable "envoyer"
    if(isset($_POST['valider1']))
    {
    //-------- on filtre les champs ---------------
    $idArticle= array_map( 'intval', $_POST['idArticle'] );
    $contenu = array_map( 'mysql_real_escape_string', $_POST['contenu'] );
     
    $select="SELECT id FROM definitions WHERE id IN (".implode(',', $idArticle).") ";
    $resultat = mysql_query("$select");
    while 
    ($R = mysql_fetch_array($resultat)) 
    {
    $updater="UPDATE  `articles` SET article='".$contenu."' WHERE id ='".$idArticle."'"; 
    mysql_query("$updater"); 
    ;}
    mysql_free_result($resultat);
     
    }//ferme isset['envoyer']
    ?>
    Merci d'avance :-)

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 305
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 305
    Points : 15 633
    Points
    15 633
    Par défaut
    affiche ta requête pour vérifier qu'elle est correcte

  3. #3
    Inscrit
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    531
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 531
    Points : 282
    Points
    282
    Par défaut
    Salut Mathieu,

    J'ai donc ajouté cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     mysql_query($updater) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error());
    Ca n'affiche rien, pas de message d'erreur ni rien.

    A mon avis, le problème provient du tableau avec le contenu des articles dans la deuxième requête. Je n'indique pas "contenu[]" mais "contenu" et ça rate.
    Mais c'est pas juste comme ça, ce serait trop beau.

  4. #4
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 305
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 305
    Points : 15 633
    Points
    15 633
    Par défaut
    dans le même formulaire tu as plusieurs zone correspondant chacune à un autre article ?

    si c'est ça, construit ton formulaire comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    foreach / while () {
        ?>
            <textarea cols="50" rows="20" name="contenuArticle[<?php echo htmlspecialchars($idArticle);?>]"><?php echo htmlspecialchars($contenuArticle);?></textarea>
        <?php
    }
    et ensuite pour le traitement du formulaire regarde ce qui se trouve dans la variable $_POST['contenuArticle']

  5. #5
    Inscrit
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    531
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 531
    Points : 282
    Points
    282
    Par défaut
    Hum, alors j'ai changé cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    //suppression de l'input hidden, on passe l'id de l'article dans l'attribut name
    <textarea cols="50" rows="20" name="contenu['.$idArticle.']">'.stripslashes($def).'</textarea><p>
    Le code censé s'exécuter après validation du formulaire :
    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
    20
    <?php
    //si il y a la variable "envoyer"
    if(isset($_POST['valider']))
    {
    
    $contenu = array_map( 'mysql_real_escape_string', $_POST['contenu'] );
    //on va chercher les id des hidden ( sans doute inutile vu qu'on les a, mais c'est pour le while et je n'ai pas envie de réétudier el script)
    $select="SELECT id FROM articles WHERE id IN (".implode(',', $contenu).") ";
    $resultat = mysql_query("$select");
    while 
    line 11 ($R = mysql_fetch_array($resultat)) 
    {
    $updater="UPDATE  `articles ` SET article='".$contenu."' WHERE id ='".$contenu."'"; 
     mysql_query($updater) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error()); 
    ;}
    line 16  mysql_free_result($resultat);
    
    }//ferme isset['envoyer']
    
    ?>



    Et j'obtiens ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Warning: array_map() [function.array-map]: Argument #2 should be an array in /home/site/www/admin/menu-lien-interne-ancien.php on line 6
     
    Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in /home/site/www/admin/menu-lien-interne-ancien.php on line 12
     
    Warning: mysql_free_result(): supplied argument is not a valid MySQL result resource in /home/site/www/admin/menu-lien-interne-ancien.php on line 17

  6. #6
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 305
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 305
    Points : 15 633
    Points
    15 633
    Par défaut
    regarde ce que tu récupère dans $_POST['contenuArticle']

    ton traitement doit ressembler à ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    foreach ($_POST['contenuArticle'] as $idArticle => $contenuArticle) {
        $idArticleSQL = mysql_real_escape_string($idArticle);
        $contenuArticleSQL = mysql_real_escape_string($contenuArticle);
     
        $requete = "UPDATE `articles` SET article = '$contenuArticleSQL' WHERE id = '$idArticleSQL'";
        // ...
    }

  7. #7
    Inscrit
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    531
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 531
    Points : 282
    Points
    282
    Par défaut
    Je ne comprend pas cette méthode.

    Parce que là j'obtiens un textarea comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <textarea name="contenu[1]" > le texte de l'article </textarea>
    Bon ici, j'ai donc dans l'attribut name l'id de l'article et dans le champ lui même j'ai son contenu.

    Mais finalement, le contenu est nommé par contenu[1].

    Donc maintenant je reprend ton code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    foreach ($_POST['contenuArticle'] as $idArticle => $contenuArticle) {
        $idArticleSQL = mysql_real_escape_string($idArticle);
        $contenuArticleSQL = mysql_real_escape_string($contenuArticle);
     
        $requete = "UPDATE `articles` SET article = '$contenuArticleSQL' WHERE id = '$idArticleSQL'";
        // ...
    }
    Et là, je ne vois pas comment d'un coup tu te retrouves avec une variable $_POST['contenuArticle], une variable $idArticle et encore une variable contenuArticleSQl alors qu'au début il n'y qu'un seul attribut name...

  8. #8
    Inscrit
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    531
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 531
    Points : 282
    Points
    282
    Par défaut
    J'ai réussi comme ça, je le dis pour la science :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    name="contenu['.$id_article.']"
     
    après
     
    Code:
    while (list($id_article,$article)=each($_POST['contenu'])
    {
     
    $updater="UPDATE  `articles` SET article='".$article."' WHERE id ='".$idArticle."'";

    Enfin pour être honnête, on m'a donné la soluce

    Merci Matthieu d'avoir fait avancer le schmilblick :-)

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

Discussions similaires

  1. Requête UPDATE et tableau de champs de formulaire
    Par Azerty24100 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 03/06/2014, 15h55
  2. [SQL] Requête Update
    Par Jaafar_scorpion dans le forum Général Java
    Réponses: 3
    Dernier message: 06/12/2012, 12h51
  3. [SQL] Requête UPDATE qui ne s'exécute pas avec PHP
    Par xplose dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 16/08/2007, 09h42
  4. [SQL] Requête UPDATE en PHP
    Par zorba49 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 18/01/2007, 16h44
  5. [SQL] problème avec ma requête UPDATE
    Par carmen256 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 07/04/2006, 11h26

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