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 :

Faire un tri sur un SELECT [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 195
    Points : 77
    Points
    77
    Par défaut Faire un tri sur un SELECT
    Bonjour à tous,
    Grâce un peu à vous, mon application commence à avancer, merci !
    Je voudrai faire un tri sur un select, afficher du plus grand au plus petit, 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
    <?php
    if (isset($motclef))
    {
     $clause = "WHERE (Quand1='$motclef' or elenom like '$motclef')";
    }
    $orderby = " ORDER BY elenom ";
    $sql = "SELECT distinct elenom,elepre,divcod,elenoet FROM retenues " . $clause . $orderby;
    $resultat = mysql_query ($sql);
    echo $sql;
    while ($eleve = mysql_fetch_array ($resultat))
    {
    // début du code affichage des sanctions
      { 
    echo'<tr>';echo "<hr size=\"1\" color=\"black\">";
    echo '<br><b>
    		'.$eleve['id'].''; 
    echo '<table border="0" cellspacing="1" cellpadding="1" width="50%">';
    echo'<tr>';
    echo'<td>Nom: <B> '.$eleve['elenom'].'</b>';
    echo'<td>Prénom: <B> '.$eleve['elepre'].'';
    echo'<td>Classe: <B> '.$eleve['divcod'].'';
    $id1=$eleve['Numéro'];
    $id2=$eleve['elenoet'];
    $req="SELECT sum(Combien) from `Retenues` WHERE elenoet LIKE '$id2' ";
    $res=mysql_query($req);   
    $nb=mysql_result($res,0);echo'<tr>';
    echo'<td>Nombre total heures de retenues: <B> '.$nb.'</td>';  
    echo'</table>';	
    echo' </TD>';	
        } 
    } 
    ?>
    là il m'affiche par odre alphabétique sur le nom, je désire qu'il le fasse sur le total cad: echo'<td>Nombre total heures de retenues: <B> '.$nb.'</td>';
    une idée ?

  2. #2
    Membre averti Avatar de Sekigawa
    Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 432
    Points : 359
    Points
    359
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $req="SELECT sum(Combien) from `Retenues` WHERE elenoet LIKE '$id2' order by sum(Combien)";
    Test il me semble que c'est ça ^^

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 195
    Points : 77
    Points
    77
    Par défaut cela ne fonctionne pas
    le
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $orderby = " ORDER BY sum(Combien)";
    ne fonctionne pas, je me disais aussi c'était simple !
    ce code en mysql ne fonctionne pas, dommage....
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT distinct elenom,elepre,divcod,elenoet FROM retenues order by sum(Combien)

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    206
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 206
    Points : 87
    Points
    87
    Par défaut
    Si tu n'a qu'une table, pourquoi ne pas faire qu'une requete au lieu de 2 ?

    Du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT distinct elenom,elepre,divcod,elenoet,sum(Combien) AS heure_retenu FROM retenues " . $clause . " order by heure_retenu";

  5. #5
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT sum(Combien), elenom,elepre,divcod,elenoet
    FROM retenues 
    group by elenom,elepre,divcod,elenoet
    order by sum(Combien)

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 195
    Points : 77
    Points
    77
    Par défaut C'est nickel !
    Merci !
    quelle aide et quelle technique, je ne plaisante pas, moi un ancien....merci les jeunes !
    ps: j'ai débuté en dbase 2 !

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

Discussions similaires

  1. [Débutant] Faire un tri sur un dataset d'après la selection dans une combobox
    Par j_quillet dans le forum C#
    Réponses: 0
    Dernier message: 28/03/2015, 23h22
  2. faire une boucle sur un select
    Par reski dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 13/03/2006, 19h41
  3. Tri sur un select
    Par alexthomas dans le forum Langage SQL
    Réponses: 6
    Dernier message: 14/12/2005, 08h28
  4. [débutant] tri sur un select
    Par moog dans le forum Langage SQL
    Réponses: 3
    Dernier message: 12/06/2005, 23h59
  5. [débutant] Tri sur un select
    Par moog dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 10/06/2005, 11h06

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