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 :

trier resultat selon des chiffres


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 265
    Points : 53
    Points
    53
    Par défaut trier resultat selon des chiffres
    Bonjour

    je suis confronté a un petit souci.

    J'ai une table qui contient un champ avec des nombres a l'interieur : 0, 2, 10, 11 a qui j'ajoute +1 a chaque enregistrement.

    Je voudrais pouvoir afficher par exemple les trois plus gros chiffres.

    Et la j'ai un souci, le tri se fait bien mais, par exemple si dans ma table j'ai :
    0 ; 2 ; 11 ; 1
    le resultat va etre : 2;11;1;0 je comprends a peut près la logique de l'affichage, mais du coup, le résultat n'est bon, il faudrait que le 11 soit afficher en premier..

    Si vous aviez une astuce je suis preneur.

    Merci

  2. #2
    Membre émérite
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Points : 2 969
    Points
    2 969
    Par défaut
    Bonjour,

    Il nous faudrait un peu plus de détails pour pouvoir te répondre :
    • Sous quelle forme sont récupérés les résultats (objets, tableau...) ?
    • Comment est fait le tri (dans la requête SQL, en PHP...) ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 265
    Points : 53
    Points
    53
    Par défaut
    la requete est toute bete :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php
     
    $retour = mysql_query("SELECT * FROM user ORDER BY nbroomies DESC LIMIT 5 ");
    while ($donnees = mysql_fetch_array($retour)){
    ?>

  4. #4
    Membre émérite
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Points : 2 969
    Points
    2 969
    Par défaut
    OK,

    Donc le tri se fait via ta requête SQL.

    Le champ nbroomies est bien de type numérique ?

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    265
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 265
    Points : 53
    Points
    53
    Par défaut
    oui c'est le champ qui contient les nombres : 0, 2, 11, 250 par exemple

  6. #6
    Membre émérite
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Points : 2 969
    Points
    2 969
    Par défaut
    C'est bizarre,

    Si le champ est numérique, le tri devrait fonctionner comme tu le souhaites.

    Or, dans ton exemple, le tri se fait comme pour des chaînes de caractères.

    Tu pourrais lancer la commande SQL suivante ?
    Et nous montrer ce qu'elle retourne ?

  7. #7
    Membre expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Points : 3 947
    Points
    3 947
    Par défaut
    Salut

    oui c'est le champ qui contient les nombres : 0, 2, 11, 250 par exemple
    Ce n'est pas normal, un ORDER BY nbroomies DESC doit faire le tri du plus grand au plus petit, peut importe le nombre d'enregistrement.

    Personnellement je ne vois que 2 cas (principaux) :
    - Soit le champ "nbroomies" ne correspond pas aux données ou doit s'appliquer le tri.
    - Soit la Bdd présente un réel problème (ce qui est rare tout de même).

  8. #8
    Candidat au Club
    Homme Profil pro
    Enseignant
    Inscrit en
    Septembre 2010
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1
    Points : 2
    Points
    2
    Par défaut
    Salut.
    je pense que le problème n'est pas au niveau de la requête, mais plutôt au niveau de la base de données. En fait, si le type du champ dans lequel tu enregistre les nombres est varchar ou char, alors les données seront traitées comme des chaînes de caractères. Ce que tu devrais faire c'est de changer le type en int et réessayer.
    J'espère que ca pourra t'aider

Discussions similaires

  1. Trier une vue tree selon des critères de recherches
    Par alexdess dans le forum Odoo (ex-OpenERP)
    Réponses: 5
    Dernier message: 09/07/2014, 15h08
  2. Trier selon des critères successifs
    Par AkaiKen dans le forum Langage SQL
    Réponses: 4
    Dernier message: 25/10/2010, 13h47
  3. trier des chaines contenant des chiffres
    Par Jerome38190 dans le forum Langage
    Réponses: 3
    Dernier message: 30/04/2010, 09h50
  4. Trier un TStringGrid avec des chiffres
    Par ddubois dans le forum Langage
    Réponses: 16
    Dernier message: 16/06/2008, 19h04
  5. [VB-Excel]Trier une valeur comprennant des lettres et des chiffres
    Par DomBourti dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 06/07/2006, 21h51

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