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

MySQL Discussion :

requete sql des 20 derniers enregistrements


Sujet :

MySQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 16
    Points : 11
    Points
    11
    Par défaut requete sql des 20 derniers enregistrements
    Bonjour a tous

    j'ai un petit soucis concernant une requête sql :
    voila la théorie :

    je cherche a afficher la liste des 20 derniers enregistrements d'une table mysql
    classée par ordre décroissant et grouper sur un champs

    voila la pratique :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT id, id_client
    FROM historique
    GROUP BY id_client
    Order by id DESC
    limit 20;
    le problème vient du fait de l'affichage des valeurs elles affichent bien les enregistrements qui ont des id_client différents mais il n'affiche pas les 20 derniers mais les 20 premiers de ma table mais bien en ordre décroissant

    pourriez-vous m'aider
    je suis complètement perdu

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    salut,

    tu veux la liste des 20 derniers id_client? c'est à dire les id_client les plus grand?

    si oui, quelque chose dans ce style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT id, max(id_client) as maxi
    FROM historique
    GROUP BY id_client
    ORDER BY maxi DESC
    LIMIT 20;

  3. #3
    Membre actif
    Homme Profil pro
    PDG
    Inscrit en
    Septembre 2005
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : PDG
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Septembre 2005
    Messages : 101
    Points : 225
    Points
    225
    Par défaut
    Avec un DISTINCT (ou DISTINCTROW) ça n'irait pas mieux ?
    Je suppose que l'id est unique, donc il suffirait d'appliquer le DISTINCT sur le id_client

  4. #4
    Membre régulier Avatar de Macfurp
    Inscrit en
    Octobre 2006
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 62
    Points : 76
    Points
    76
    Par défaut
    Bonjour,
    le group by sur id_client seul provoquer de n'avoir en résultat que la dernière valeur d'id, pour que cela fonctionne il faudrait regrouper sur id_client + id :


    SELECT id, id_client
    FROM historique
    GROUP BY id_client, id
    ORDER BY id DESC
    LIMIT 20;

Discussions similaires

  1. [MySQL] Affichage des deux derniers enregistrements
    Par breizhgen dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 12/12/2006, 21h13
  2. [MySQL] Affichage des deux derniers enregistrements
    Par breizhgen dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 19/11/2006, 16h23
  3. Réponses: 5
    Dernier message: 29/12/2005, 07h03
  4. [debutant] selection des 6 derniers enregistrements
    Par LoLoSS dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/07/2004, 15h27
  5. Réponses: 10
    Dernier message: 01/08/2003, 13h45

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