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 PHP liste déroulante méthode d'insertion ? [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Par défaut SQL PHP liste déroulante méthode d'insertion ?
    Bonjour à tous,

    Voila je voulais savoir si c'est possible de faire une liste déroulante avec les données : A;B;C;D;E;F qui correspondra à des id : 1;2;3;4;5;6 qui seront stockés dans une table "batiment" sachant que les données seront envoyé dans la table "salle"

    Table "batiment"
    -idBat= 1;2;3;4;5;6
    -Lettre=A;B;C;D;E;F
    -Nom=al;bo;ce;de;ef;fe

    Table "salle"
    -id=3;6;4;5 (auto increment)
    -idBat= cela correspondra au idBat de la table batiment = 1;2;3;4;5;6
    -numSalle= 502

    Voila j'espere que vous avez compris

    Si vous avez besoin de plus d'informations n'hésitez pas

  2. #2
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 509
    Par défaut
    Saut,

    Il faut d'abord te connecter à la base de donnée avec un driver (PDO ou mysqli) puis tu lance une requête qui renvoie toutes les lignes de la table bâtiment.

    Exemple de PDO:
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    $connection=new PDO('mysql:host=localhost;dbname=nom_de_base', 'nom_utilisateur', 'mot_de_passe', array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'));
    $req="select idBat,Lettre from batiment";
    $prepared=$connection->prepare($req);
    $prepared->execute();
    $select='<select>';
    if($prepared->rowCount()>0){ 
       while($data=$prepared->fetch(PDO::FETCH_ASSOC)){
          $select.= "<option value='".$data['idBat']."'>".$data['Lettre']."</option>";
       }
    }
    else {$select.="<option value=0>Aucune donnée n'a été trouvée</option>";}
    $select.="</select>";
    echo $select;
    $connection=null;

    puis pour insérer l'id bâtiment dans la table salle, tu n'as qu'a prendre la "value" de l'option sélectionnée.

  3. #3
    Membre confirmé Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Par défaut
    D'accord merci pour ton aide mais j'ai pas trop compris le code avec le select

  4. #4
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 509
    Par défaut
    qu'est ce que tu n'as pas compris ? la concaténation en php ?

  5. #5
    Membre confirmé Avatar de IamKanagawa
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2018
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2018
    Messages : 114
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    $req="select idBat,Lettre from batiment";
    $prepared=$connection->prepare($req);
    $prepared->execute();
    $select='<select>';
    if($prepared->rowCount()>0){ 
       while($data=$prepared->fetch(PDO::FETCH_ASSOC)){
          $select.= "<option value='".$data['idBat']."'>".$data['Lettre']."</option>";
       }
    }
    else {$select.="<option value=0>Aucune donnée n'a été trouvée</option>";}
    $select.="</select>";
    echo $select;
    $connection=null;
    j'ai compris que la requête affiche "idbat et lettre" puis si il trouve quelque chose il prends 1 comme valeur et on rentre dans le if et la je suis plus

  6. #6
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 509
    Par défaut
    1-c'est une boucle while qui stocke les items trouvés de $prepared->fetch(PDO::FETCH_ASSOC) dans la variable $data.
    $prepared->fetch(PDO::FETCH_ASSOC) retourne un tableau ayant la structure :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    [
       ["idBat"=>1,"Lettre"=>"A"],
       ["idBat"=>2,"Lettre"=>"B"],
       ["idBat"=>3,"Lettre"=>"C"],
       ["idBat"=>4,"Lettre"=>"D"],
       ["idBat"=>5,"Lettre"=>"E"],
       ["idBat"=>6,"Lettre"=>"F"]
    ];
    maintenant il va falloir parcourir ce tableau pour créer les options selon ses valeurs "idBat" et "Lettre" :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    $select="<select>";//ouverture de la balise <select>
    while($data=$prepared->fetch(PDO::FETCH_ASSOC)){//on ajoute les options dans la variable $select
       $select.= "<option value='".$data['idBat']."'>".$data['Lettre']."</option>";
       /* résultat :
       <select>
         <option value="1">A</option>
         <option value="2">B</option>
         <option value="3">C</option>
         <option value="4">D</option>
         <option value="5">E</option>
         <option value="6">F</option>
       */
    }
    $select.="</select>"; /*On ferme la balise <select> qu'on a ouvert au début du script, c'est équivalent à $select=$select."</select>";*/

    2-cette ligne
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     $select.= "<option value='".$data['idBat']."'>".$data['Lettre']."</option>";

    est équivalente à
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     $select=$select."<option value='".$data['idBat']."'>".$data['Lettre']."</option>";

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 20/02/2008, 12h30
  2. [JS-PHP] Liste déroulante générée dynamiquement
    Par Sytchev3 dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 18/09/2007, 17h43
  3. [PHP-JS] Problème javascript php liste déroulante
    Par bodysplash007 dans le forum Langage
    Réponses: 2
    Dernier message: 26/03/2007, 11h06
  4. php , liste déroulante
    Par marie4449 dans le forum Langage
    Réponses: 3
    Dernier message: 22/03/2007, 12h45
  5. [SQL] pb liste déroulante
    Par lecail65 dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 31/07/2006, 11h11

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