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 :

Checkbox et Mysql


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé Avatar de Addict`
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2008
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2008
    Messages : 148
    Par défaut Checkbox et Mysql
    Bonjour,

    Mon problème porte sur les Checkbox et plus précisement sur leur enregistrement dans une base de données afin de les exploiter.

    En effet, je me sers des checkbox lors de l'ajout d'un nouveau membre en lui attribuant des droits comme le montre les code suivant :

    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
    				<form name="upload" method="post" action="script_membres.php" enctype="multipart/form-data">
    					<h3> Ajouter un membre </h3>
    					<p><label for="name">Nom</label></p>
    					<p><input type="text" name="name" /></p>
    					<p><label for="prenom">Pr&eacute;nom</label></p>
    					<p><input type="text" name="prenom" /></p>
    					<p><label for="password">Mot de passe</label></p>
    					<p><input type="text" name="password" /></p>
    					<p><label for="mel">Adresse Mel</label></p>
    					<p><input type="text" name="mel" /></p>
    					<p>a acc&eacute;s aux commissions :</p>
    					<p><input type="checkbox" name="com[]" value="A"> Billetterie (A)
    					<input type="checkbox" name="com[]" value="B"> Culturelle (B)
    					<input type="checkbox" name="com[]" value="C"> Sportive (C)
    					<input type="checkbox" name="com[]" value="D"> Voyage (D)</p>
    					<p><input type="checkbox" name="com[]" value="E"> Admin Général (E)</p>
     
    					<p><input type="submit" name="ok" value="Ajouter" /></p>
    				</form>
    Donc pour le moment pas bien compliqué !

    Ensuite lorsque je traite la demande d'ajout, j'éxécute mon script suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <?php
    include('../include/session.inc.php');
     
    if(isset($_POST['name']) && isset($_POST['prenom']) && isset($_POST['mel']) && isset($_POST['password']) && !empty($_POST['name']) && !empty($_POST['prenom']) && !empty($_POST['password']) && !empty($_POST['mel']) && isset($_POST['ok'])){
    		include('../include/connect.inc.php');
    		$_SESSION['droits']=$_POST['com'];
    		$query = mysql_query("INSERT INTO admin (id_admin,nom_admin,prenom_admin,pass_admin,mel_admin,droits_admin) VALUES ('','".$_POST['name']."','".$_POST['prenom']."','".$_POST['password']."','".$_POST['mel']."','".$_SESSION['droits']."')");
    		mysql_close();
    		header("location: gestion_membres.php");
    	}
    	else{
    		echo'erreur';
    	}
    ?>
    Au final, mon problème, c'est que les checkbox sélectionnées s'enregistrent sous la forme d'un tableau renvoyant 'Array' dans ma table...

    Et là, c'est le choc ! Comment je peux faire pour avoir dans ma table un truc du style A;B;C;D que je puisse exploité après ?

    Merci d'avance

  2. #2
    Membre très actif
    Avatar de keaton7
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    743
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 743
    Par défaut
    Pour répondre a moitie a ta question, je pense qu'il serait plus judicieux et plus flexible de faire une table intermediaire entre ta table de droits et ta table de users. Ca te permettra de creer des sections supplementaires quand tu veux et d'y attribuer des droits plus aisement.

    Apres pour ta question precise, dans ta table, tu ne peux pas enregistrer un tableau a moins de le serialiser. Dans ton cas c'est inutile. Pour faire ce que tu veux faire, et que je ne te conseille pas () il faut que tu passes par une commande intermediaire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $valeurs = "";
    $count = count($_POST['com']);
    for ($i=0;$i<$count;$i++) {
      $valeurs .= "{$_POST['com'][$i]};";
    }
    $_SESSION['droits']=$valeurs;

  3. #3
    Membre confirmé Avatar de Addict`
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2008
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2008
    Messages : 148
    Par défaut
    Salut !

    Si tu ne me le conseilles pas alors que me propose tu ? Je vais suivre ta proposition et créer une nouvelle table regroupant mes différents droits !

    Merci

  4. #4
    Membre très actif
    Avatar de keaton7
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    743
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 743
    Par défaut
    Bah ce que je te conseille c'est de creer 3 tables :
    ADMINS(id_admin,...)
    DROITS(id_droit,...)
    RELATIONS_ADMIN_DROITS(id_admin,id_droit)

    Enfin tu vois l'idee .

    Du coup ton probleme de traitement de tableau, il te faudra faire un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $sql = "";
    $count = count($_POST['com']);
    for ($i=0;$i<$count;$i++) {
      $sql .= "INSERT INTO `RELATIONS_ADMINS_DROITS` VALUES ('{$_POST['id_admin']}','{$_POST['com'][$i]}');";
    }
    Avec $_POST['com'][$i] l'id des droits en traitement.

  5. #5
    Membre confirmé Avatar de Addict`
    Profil pro
    Étudiant
    Inscrit en
    Septembre 2008
    Messages
    148
    Détails du profil
    Informations personnelles :
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Septembre 2008
    Messages : 148
    Par défaut
    Yes je vois mieux ! merci bien à toi !

Discussions similaires

  1. [MySQL] checkbox et mysql
    Par gueud dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 13/05/2008, 23h27
  2. Réponses: 5
    Dernier message: 18/02/2008, 16h11
  3. Inserer valeur checkbox dans MySQL
    Par Kornikopic dans le forum IHM
    Réponses: 3
    Dernier message: 19/06/2007, 13h22
  4. probleme checkbox et mysql
    Par faucon54 dans le forum SQL Procédural
    Réponses: 10
    Dernier message: 16/05/2007, 21h04
  5. Récupérer des valeurs de checkbox dans MySQL
    Par digger dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 05/09/2005, 14h58

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