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 :

Récupérer données des checkbox pour les insérer dans plusieurs colonnes 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
    Inscrit en
    Avril 2010
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 43
    Par défaut Récupérer données des checkbox pour les insérer dans plusieurs colonnes MySQL
    Bonjour,

    Je voudrai récupérer les valeurs des checkbox de mon formulaire, et les insérer dans ma BDD MySQL.

    Pour la partie récupération des valeurs, pas de soucis, j'arrive à récupérer les valeurs, et à les afficher.
    J'arrive même à les insérer en BDD, mais mon problème est que je n'arrive à les insérer que dans une seule colonne.

    Je m'explique:

    Un étudiant effectue plusieurs voeux, pour ses études superieures, (prépas, eco gestion, medecine, bts, etc...)
    Lorsque les données sont sauvegardées en base, impossible de prendre chacun des voeux pour les mettre dans plusieurs colonnes respectives (filiere1choisie, filiere2choisie,filiere3choisie...)

    Lorsque je n'ai qu'une seule colonne (filierechoisie),et pas filiere1choisie, filiere2choisie... l'insertion se fait correctement, avec donc plusieurs lignes, en fonction des filières choisies.

    Voici mon code PHP:

    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
     
     
    <?php
    mysql_connect("localhost", "root", "") or die(mysql_error());
    mysql_select_db("voeuxetudiants") or die(mysql_error());
     
    $checkbox1 = $_POST['fonction'];
    if($_POST["submit"]=="submit")
    {   
    	for ($i=0;$i<sizeof($checkbox1);$i++){    
        $query="INSERT INTO  choix VALUES ('" . $checkbox1[$i] . "')";     
     
        mysql_query($query) or die (mysql_error() );
    }
     
     
    }
     
    ?>

    et voici mon code HTML

    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 method="post" action="traitement.php">
       <p>Voeux Etudiants</p>
     
       <input type="checkbox" name="fonction[]" value="BAC S" />BAC S<br />
       <input type="checkbox" name="fonction[]" value="BAC ES" />BAC ES<br />
       <input type="checkbox" name="fonction[]" value="BAC L" />BAC L<br />
       <input type="checkbox" name="fonction[]" value="BAC PRO" />BAC PRO<br />
     
     
    </br>
    </br>
       <input type="submit" value="submit" name="submit"/>
    </form>
    Je précise, que niveau BDD, je n'ai qu'une table: choix.
    Dans la table choix, je n'ai actuellement qu'un seul champs (filierechoisie), mais je voudrais donc pouvoir mettre plusieurs champs: fliliere1choisie,filiere2choisie etc.


    Merci pour votre aide

  2. #2
    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
    Par défaut
    impossible de prendre chacun des voeux
    non ce n'est pas impossible.

    Ce que tu fais est bon : on fait bien une insertion par voeux et non pas une colonne par voeux.
    Par contre il manque l'identification de l'étudiant dans ta requête.

    Au passage également, ton code est préhistorique :
    - l'extension mysql est remplacée par PDO
    - les boucles for/sizeof sont à remplacer par une boucle foreach.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre actif Avatar de monaka
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2017
    Messages
    64
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mars 2017
    Messages : 64
    Par défaut
    salut , faire un insert dans ta boucle for signifie créer autant de ligne dans ta table qu'il y'a de checkbox sélectionnée

    je ne crois pas qu'il n'est possible d'attribuer plusieurs valeurs à un champ à moins d’être peut-être une concaténation

    ensuite le nombre de vœux est il limité? sinon du devra créer autant de champs filières que de filières disponibles sans oublier l'id qui est la clé primaire et auto_incrémenté

    d'ou je te propose ceci pour une minime satisfaction avant de passer à pdo

    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
    <?php
    mysql_connect("localhost", "root", "") or die(mysql_error());
    mysql_select_db("voeuxetudiants") or die(mysql_error());
     
    $checkbox1 = $_POST['fonction'];
    $i=0;
    if($_POST["submit"]=="submit")
    {   
     
        $query="INSERT INTO  choix VALUES (null,'" . $checkbox1[$i] . "','" . $checkbox1[$i+1] . "','" . $checkbox1[$i+2] . "')";     
     
        mysql_query($query) or die (mysql_error() );
     
        echo "Complete";
     
    }
     
    ?>
    pour ce qui me vient rapidement en tete, et valables pour 3 choix donc choix(id,filiere1,filiere2,filiere3)

    et pour plus optimisé les super modo sont présent, à propos vous m’épatez tous les modos

Discussions similaires

  1. Réponses: 17
    Dernier message: 12/12/2016, 19h05
  2. [XL-2010] FICHIER PDF / récupérer chaîne de caractère pour les insérer dans usf
    Par GADENSEB dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 25/04/2014, 15h01
  3. Recuperer le nom des onglets pour les mettre dans une colonne
    Par nico4566 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 21/03/2011, 17h23
  4. Réponses: 1
    Dernier message: 31/01/2007, 11h59
  5. Récupérer infos page html pour les insérer dans Outlook
    Par andromede88 dans le forum Windows
    Réponses: 4
    Dernier message: 21/09/2006, 14h21

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