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 :

Liste déroulante dynamique oracle


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2011
    Messages : 7
    Points : 6
    Points
    6
    Par défaut Liste déroulante dynamique oracle
    Bonjour à tous,

    Voila je vous explique mon problème :

    j'ai un formulaire php qui va récupérer les valeurs dans une base.

    J'ai un formulaire avec 3 listes déroulantes et en fonction du choix de la première la 2ème liste déroulante ne proposera que certains choix et enfin selon le choix le la 2ème liste la 3è liste ne proposera également que certains choix.

    Liste déroulante 1 : Choix de la Direction Générale
    Liste déroulante 2 : Choix de la Direction
    Liste déroulante 3 : Choix du service

    Voici mes tables Oracle :

    DirectionGénérale(Id,Nom)
    Direction(Id,Nom,IdDirectionGénéral)
    Service(Id,Nom,IdDirection)

    J'en suis a ce point au nivau de mon formulaire, j'arrive à récupérer les valeur de ma table Direction Général et a les afficher, mais je n'arrive pas à afficher les direction correspondantes dans une liste déroulante en dessous.

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    <center><h1> FICHE </h1></center>
    <h2>Généralités</h2>
    <form action="testazerty.php" method="post">
    <div>
    <TABLE BORDER=0>
     
     
    Direction Générale Adjointe :
     
    <!-- Recuperation données -->
     
    <?php
     
    $con = ocilogon( "test", "test" ,"IDCON"); 
    $reqdirgen = "select NOM, Id from DIRECTIONGENERALE";
     
    $parsed = ociparse($con, $reqdirgen);
    ociexecute($parsed);
     
    $nrows = ocifetchstatement($parsed, $results);
    echo "<select name=NOM>\n";
    for ($i = 0; $i < $nrows; $i++) 
    {
    //echo "<option value={$results['NOM'][$i]}>";
    echo "<option value=\"".$results['NOM'][$i]."\">".$results['NOM'][$i] ."</option>";
    }
    $code = $_POST['NOM'] ;
    echo( "Votre dga: <b>".$code."</b><br>\n" ) ;
    oci_free_statement($parsed);
    oci_close($con);
     
    ?>

    Je ne suis pas un spécialiste je préviens par contre je débute ^^

    Merci de votre aide j'espère avoir été claire :/

  2. #2
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    J'en suis a ce point au nivau de mon formulaire, j'arrive à récupérer les valeur de ma table Direction Général et a les afficher, mais je n'arrive pas à afficher les direction correspondantes dans une liste déroulante en dessous.
    Pour tout ce qui est dynamique, il faut passer par JavaScript. Dans ton cas, il faut créer un trigger Ajax capable d'aller demander à PHP les directions pour une direction générale et d'afficher une liste déroulante en dessous.

    Voici à quoi ça peut ressembler avec du JSon et jQuery:
    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
     
    $('select#dir_general').change(function () {
      $.ajax({
         url: '/get_directions_from_general_direction.php',
         data: {id_dir_gen: $(this).val()},
         context: $(this),
         dataType: 'json',
         success: function (json) {
             var directions = $('<select name="direction"></select>'):
             $.each(json.directions, function (i, item) {
                 directions.append('<option value="' + i + '">' + item + '</option>');
             });
             $('select[name="direction"]').remove();
             $(this).after(directions);
         }
      });
    });
    Le script get_directions_from_general_direction.php prends un id_dir_get en paramètre $_GET et devra renvoyer un flux JSon qui comprends les directions à afficher - tu peux te servir d'un bête tableau et de la fonction json_encode pour faire ça.

Discussions similaires

  1. récupérer la valeur d'une liste déroulante dynamique
    Par grinder59 dans le forum Général JavaScript
    Réponses: 21
    Dernier message: 23/01/2006, 17h51
  2. Liste déroulante dynamique
    Par Screw16 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 30/10/2005, 20h37
  3. [HTML] liste déroulante dynamique
    Par lacousinee dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 04/08/2005, 20h51
  4. Liste déroulante dynamique ?
    Par Regis.C dans le forum Composants
    Réponses: 5
    Dernier message: 29/06/2005, 12h09
  5. [FORMULAIRE] Liste déroulante dynamique
    Par bchristo dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 18/01/2005, 10h07

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