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 :

Problème avec une liste déroulante [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    65
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Dom-Tom

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2011
    Messages : 65
    Points : 39
    Points
    39
    Par défaut Problème avec une liste déroulante
    Bonsoir,

    J'ai réussi à créer un code qui pour moi à l'air de fonctionner qui est censé récupérer dans une table Mysql l'année d'une date et ainsi le mettre dans un menu déroulant.

    Le problème s'est que le menu déroulant est vide et je ne trouve pas la raison.

    Merci d'avance de votre aide.

    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
    33
    34
    35
    36
    37
    38
    <?php
          $host = "127.0.0.1";
          $user = "root";
          $pass = "";
          $bdd = "glpi";
     
    $cnx = mysql_connect($host,$user,$pass) or die("Impossible de se connecter");
             $db = mysql_select_db("$bdd") or die("Impossible de se connecter");
     
    if (mysql_connect ($host,$user,$pass))
                {
                   echo 'Connexion réussie'; echo '<br>';
                }
                else
                {
                   echo 'Connexion impossible...'.mysql_error(); echo '<br>';
                } 		 
    ?>
     
    <?php
    echo '<select size=1 name="cat">'."\n"; 
      echo '<option value="-1">Choisir un résultat<option>'."\n"; 
     
      // Récupération des informations triées par ordre alphabétique 
    $sql = "SELECT YEAR('date') as texte FROM glpi_excel GROUP BY YEAR(`date`)";
     
     
    $req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
     
     
    while($data = mysql_fetch_assoc($req))
    {
    // on affiche les informations de l'enregistrement en cours
    echo '<option value='.$data['texte'].'>'.$data['texte'].'';
    echo '</option>'.'\n';
    }
     
    ?>

  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 : 37
    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
    Où est le tag fermant </select> ?

    Au passage:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error())
    Est une très mauvaise pratique (y compris en dev)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if (!$req = mysql_query($sql)) {
      echo "ERREUR SQL";
    }
    Est une bonne pratique

  3. #3
    Rédacteur/Modérateur

    Avatar de Jiyuu
    Homme Profil pro
    Développeur amateur
    Inscrit en
    Janvier 2007
    Messages
    2 456
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur amateur
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 456
    Points : 6 789
    Points
    6 789
    Billets dans le blog
    15
    Par défaut
    Bonjour,

    Je me permets d'intervenir au cas où la réponse de Benjamin ne résout pas globalement ton problème.

    J'ai tout récemment eu le même souci que toi (peut-être pas les même causes cela-dit) et pour y remédier j'ai opté pour une autre méthode qui consistait à compter le nombre de ligne de résultat de ma requête et de répéter X fois le code .

    Voila ce que ça donne :
    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
    $i=0;
    $ligne=0;
    $tab=array();
     
    	while ($tableau=mysql_fetch_array($result)){
    		$tab[$i]['id']=$tableau['id'];
    		$tab[$i]['user_titre']=$tableau['user_titre'];
    		$tab[$i]['user_nom']=$tableau['user_nom'];	
    		$i=$i+1;
      }
     
    $i = 0;
     
    $select = "<form method='POST' action=enregistrement.php?parent=selection>
    		<select size='1' name='ligne'>";
    while ($i<$nbResults){
    	$select = $select. "<option value=".$tab[$i]['id'].">".$tab[$i]['user_titre'].". ".$tab[$i]['user_nom']."</option>";
    	$i=$i+1;
    	}
    $select = $select."</select>
    		<input type='submit' value='Envoyer' name='go'>
    		</form>";
     
     
    echo $select."<br><br>";
    Espérant avoir pu t'aider.

    ++

    J

  4. #4
    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 : 37
    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
    Ah et j'en profite pour faire remarque que '\n' n'est pas le caractère retour charriot mais bien backslash n. Pense à utiliser les double quotes

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2011
    Messages
    65
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Dom-Tom

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2011
    Messages : 65
    Points : 39
    Points
    39
    Par défaut
    Merci pour vos nombreuse réponse.^^

    Au final mon problème se situais au niveau de ma requête en retirant les " ' " dans date, le résultat de ma requête apparait à présent.^^

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql = "SELECT YEAR(date) as texte FROM glpi_excel GROUP BY YEAR(date)";

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 09/02/2011, 16h31
  2. Problème avec une liste déroulante
    Par flippaeti dans le forum C#
    Réponses: 1
    Dernier message: 05/06/2009, 20h46
  3. Problème avec une liste déroulante.
    Par kupae dans le forum IHM
    Réponses: 9
    Dernier message: 09/07/2008, 11h12
  4. problème avec une liste déroulante
    Par valouche dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 30/05/2007, 10h01
  5. [Débutant] problème avec une liste déroulante
    Par stan21 dans le forum Access
    Réponses: 3
    Dernier message: 12/07/2006, 15h52

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