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

Langage PHP Discussion :

Comment supprimer plusieurs champs dans un formulaire?


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut Comment supprimer plusieurs champs dans un formulaire?
    Bonjour à tous,

    J'ai crée un formulaire d'où je souhaite pouvoir effacer plusieurs "entrées" à la fois mais malheureusement avec le code mis en place je ne peux le faire qu'un par un.

    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
     
    <form action="/mapage.php" method="post" >
    <input type="checkbox" value="ma_valeur" id="mon_id" name="mon_id" />
    <input type="submit" name="supprimer" value="Supprimer" />
    </ form>
     
    Dans mapage.php
    if ( isset($_POST['mon_id'])) {
    $sMonId = ereg_replace("'", "`", $_POST['mon_id'] );
     
    $sqlQuery =
    " DELETE FROM matable WHERE MON_ID = '$sMonId' ";
    mysql_query($sqlQuery);
    checkSqlError($sqlQuery);
    }
    De quelle manière dois-je m'y prendre pour pouvoir en supprimer plusieurs à la fois ?

    Merci beaucoup par avance,

    Aurélien

  2. #2
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    <form action="/mapage.php" method="post" >
    <input type="checkbox" value="ma_valeur" name="mon_id[]" />
    <input type="checkbox" value="ma_valeur1" name="mon_id[]" />
    <input type="checkbox" value="ma_valeur2" name="mon_id[]" />
    <input type="checkbox" value="ma_valeur3" name="mon_id[]" />
    <input type="submit" name="supprimer" value="Supprimer" />
    </ form>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    if ( isset($_POST['mon_id'])) {
    	foreach($_POST['mon_id'] as $id){
    		$sMonId = ereg_replace("'", "`", $id );
    		$sqlQuery =" DELETE FROM matable WHERE MON_ID = '$sMonId' ";
    		mysql_query($sqlQuery);
    		checkSqlError($sqlQuery);
    	}
    }
    ?>
    A+.

  3. #3
    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
    En une seule requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (isset($_POST['mon_id'])) {
           $tblId = array_map('intval', $_POST['mon_id']);
    $sqlQuery =" DELETE FROM matable WHERE MON_ID IN (" . implode(',', $tblID) . ')';
          mysql_query($sqlQuery);
    }

  4. #4
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    Merci pour vos réponses.

    Sabotage : ton code me renvoi une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Warning: array_map() [function.array-map]: Argument #2 should be an array in /homez.318/site/www/mapage.php on line 10
     
    Warning: implode() [function.implode]: Invalid arguments passed in /homez.318/site/www/mapage.php on line 11
     
    Warning: Cannot modify header information - headers already sent by (output started at /homez.318/site/www/mapage.php:10) in /homez.318/site/www/mapage.php on line 24
    As-tu une idée d'où cela pourrait venir ?

    Merci pour votre aide.

    Aurélien

  5. #5
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    As-tu modifié le name des input ?

  6. #6
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    Non mais j'ai essayé en le modifiant et ça ne corrige pas le problème.

  7. #7
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    A priori il y aurait une erreur de syntaxe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Warning: array_map() [function.array-map]: Argument #2 should be an array in /homez.318/site/www/mapage.php on line 10
     
    Warning: implode() [function.implode]: Invalid arguments passed in /homez.318/site/www/mapage.php on line 11
     
    DELETE FROM matable WHERE ID IN ()
    à causé une erreur sur le serveur mySql:
    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1

  8. #8
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    fait au début de ton code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo '<pre>', print_r($_POST, true), '</pre>';

  9. #9
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    Voila le résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Array
    (
        [supprimer] => Supprimer
        [mon_id] => 2020
    )
    A priori mon post fonctionne bien.

  10. #10
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    non t'as pas fait comme andry.aime t'as dis

    name="mon_id[]"

  11. #11
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Citation Envoyé par AurelienNF Voir le message
    Non mais j'ai essayé en le modifiant et ça ne corrige pas le problème.


    EDIT: owned par stealth35

  12. #12
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    J'avais effectivement bien essayé mais il y avait toujours une erreur.
    Néanmoins mea culpa puisqu'à priori il fallait le faire.

    Par contre une erreur persiste:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Array
    (
        [supprimer] => Supprimer
        [mon_id] => Array
            (
                [0] => 2020
            )
    )
     
    Warning: implode() [function.implode]: Invalid arguments passed in /homez.318/site/www/mapage.php on line 13
     
    DELETE FROM matable WHERE ID IN ()
    à causé une erreur sur le serveur mySql:
    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1

  13. #13
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Essaie avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sqlQuery =" DELETE FROM matable WHERE MON_ID IN (" . implode(',', $_POST['mon_id']) . ')';

  14. #14
    Membre régulier
    Homme Profil pro
    Consultant E-Business
    Inscrit en
    Août 2010
    Messages
    216
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant E-Business

    Informations forums :
    Inscription : Août 2010
    Messages : 216
    Points : 96
    Points
    96
    Par défaut
    MERCI MERCI MERCI !!!

    Ça fonctionne super bien.

    A bientôt.

    Aurélien

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 20/01/2012, 16h27
  2. Ajouter / supprimer plusieurs éléments dans un formulaire
    Par nesswaw dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 07/03/2008, 10h52
  3. [AJAX] Auto completion - plusieurs champs dans un formulaire
    Par etco1 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 04/09/2007, 17h36
  4. Réponses: 6
    Dernier message: 30/04/2007, 23h36
  5. comment supprimer un champ dans une requete ??
    Par loran v2 dans le forum Bases de données
    Réponses: 2
    Dernier message: 24/03/2006, 20h41

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