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

Langage PHP Discussion :

lister après requète select distinct


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 13
    Par défaut lister après requète select distinct
    Salut,

    j'ai une table dans laquelle un champ "tailles" séparé par des tiret à des données de ce type :
    46 -47 -48 - 49
    45 - 46
    43 - 44 - 45
    ...

    ce que je souhaite afficher c'est les tailles disponibles sans répéter les tailles en double
    voici ce que j'ai fait, j'arrive à lister toutes les tailles, mais pas à filrer puis ordonner la liste :

    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
    $sql="SELECT DISTINCT taille from catalogue";
     
     
    //Liste des tailles pour le menu (toutes)
    $reponse  =  mysql("$DBDatabase","$sql");
    if (mysql_num_rows($reponse) > 0){
     
          while($row_taille = mysql_fetch_array($reponse)) {
     
    $taille = stripslashes($row_taille[taille]);
     
    // ici c'est pour séparer les tailles avec le tiret comme séparateur
    $mots = split(" - ", $taille);
    $nombre_de_taille = count($mots);
    $taille = explode("-", $taille);
     
    $i= 0; 
    while ( $i < $nombre_de_taille ) 
    {
     
    $option_taille="<option value=$taille[$i]  \">$taille[$i]</option>";
    echo "$option_taille // problème ici car j'affiche toutes les tailles 
    ";
    $i++;
    }
     
    	}
    }
    je suppose qu'il faut utilisé array_unique, mais je sais pas comment faire ??
    merci de votre aide !

    Lionel

  2. #2
    Membre Expert
    Avatar de Eusebe
    Inscrit en
    Mars 2006
    Messages
    1 992
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 992
    Par défaut
    Bonjour,

    Pourquoi fais tu un split puis un explode ?
    Et à quoi sert ton stripslashes ?

    Il faut que tu rassemble toutes tes tailles dans un même tableau, puis que tu fasses l'affichage après. Quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $tailles = array();
    while($row_taille = mysql_fetch_array($reponse))
    {
        $tailles_tmp = explode(' - ', $taille);
        $tailles = array_merge($tailles, $tailles_tmp);
    }
     
    $tailles = array_unique($tailles); 
    sort($tailles);
     
    foreach ($tailles as $taille)
    {
        echo '<option value="'.$taille.'">'.$taille.'</option>';
    }

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 13
    Par défaut merci ! ça marche nickel
    ton code marche très bien, il manquait jusque une ligne :

    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
     
    $tailles = array();
    while($row_taille = mysql_fetch_array($reponse))
    {
        $taille = $row_taille[taille]; // ICI
        $tailles_tmp = explode(' - ', $taille);
        $tailles = array_merge($tailles, $tailles_tmp);
    }
     
    $tailles = array_unique($tailles); 
    sort($tailles);
     
    foreach ($tailles as $taille)
    {
        echo '<option value="'.$taille.'">'.$taille.'</option>';
    }
    MERCI !

  4. #4
    Membre Expert
    Avatar de Eusebe
    Inscrit en
    Mars 2006
    Messages
    1 992
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 992
    Par défaut
    Tu aurais aussi pu faire directement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        $tailles_tmp = explode(' - ', $row_taille[taille]);
    (on aurait aussi pu se passer de la variable temporaire $tailles_tmp, mais le code me semble moins lisible dans ce cas)

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 13
    Par défaut comment ordonner les résultats ?
    Comment ordonner la liste après svp ?
    Car dans la requette sql je tri l'ensemble des tailles, pas les tailles filtrées

    ça doit être la dedans :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    foreach ($tailles as $taille)
    {
        echo '<option value="'.$taille.'">'.$taille.'</option>';
    }
    Merci

  6. #6
    Membre Expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Par défaut
    Je ne te suis pas trop, le sort() que tu fais précédemment n'effectue pas le tri ?

    Si non, quel type de tri veux tu effectuer et sur quelles valeurs ?

Discussions similaires

  1. [MySQL] Copier une table après un select distinct
    Par Whombat dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 29/06/2011, 16h43
  2. [Oracle -> MySQL] requête UPDATE d'après un SELECT
    Par Paul TOTH dans le forum Requêtes
    Réponses: 2
    Dernier message: 31/03/2010, 12h50
  3. Réponses: 6
    Dernier message: 11/09/2006, 00h34
  4. Case à Cocher avec Requête SELECT DISTINCT
    Par Polo_973 dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 03/04/2006, 17h35

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