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 SQL Discussion :

[Debutante] trouver les 5 plus grandes valeurs


Sujet :

Langage SQL

  1. #1
    Membre habitué Avatar de Sarrus
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Mai 2005
    Messages : 180
    Points : 138
    Points
    138
    Par défaut [Debutante] trouver les 5 plus grandes valeurs
    Le probleme se passe sur un forum phpbb... je voudrais recuperer les 5 derniers sujets traité, en date... Il existe un champ time dans la bdd, il faudrait donc que je recupere les 5 plus grandes valeurs de la table pour ce champ... et je ne sais pas comment faire...

    Merci de votre aide

  2. #2
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Sujet traité de nombreuses fois, il existe des réponses n'utilisant que le norme SQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT a.x, a.y,...
    FROM laTable a INNER JOIN laTable b on a.Date >= b.Date
    GROUP BY a.x, a.y,...
    HAVING COUNT(*) <= 5
    Si la date n'est pas identifiante, il peut y avoir des effets de bords, et il faut décider de la stratégie.

    Sinon il y a de méthodes spécifiques à chaque moteur (ROWNUM <= 5 sous ORACLE par exemple)
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  3. #3
    Membre habitué Avatar de Sarrus
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Mai 2005
    Messages : 180
    Points : 138
    Points
    138
    Par défaut
    Pas sure d'avoir bien compris : tu fais intervenir plusieurs tables dans ton code, moi je veux juste recuperer les 5 tuple qui sont les plus récents, sur une seule table...

  4. #4
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Citation Envoyé par la_unge
    Pas sure d'avoir bien compris : tu fais intervenir plusieurs tables dans ton code, moi je veux juste recuperer les 5 tuple qui sont les plus récents, sur une seule table...
    Il n'y a qu'une seule table, a et b sont des alias.
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  5. #5
    Membre habitué Avatar de Sarrus
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Mai 2005
    Messages : 180
    Points : 138
    Points
    138
    Par défaut
    ok, et une autre question, car ce n'e sont pas les seuls criteres de selection pour la requete, puis je cumuler des INNER JOIN, avec un WHERE ? et le HAVIGN COUNT je le met apres le WHERE ?

  6. #6
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    WHERE après les conditions de JOIN.
    HAVING COUNT après le GROUP BY.
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  7. #7
    Membre habitué Avatar de Sarrus
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Mai 2005
    Messages : 180
    Points : 138
    Points
    138
    Par défaut
    bon j'ai tenté la requete.... c'est bon au niveau syntaxe ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT post_subject 
    FROM phpbb_posts a, phpbb_posts_text, phpbb_form 
    INNER JOIN phpbb_posts b on a.time >= b.time
    GROUP BY phpbb_posts_text.post_subject
    HAVING COUNT(*) <= 5 
    WHERE phpbb_posts.forum_id = phpbb_forum.forum_id 
    AND phpbb_posts.post_id = phpbb_posts_text.post_id 
    AND post_subject NOT NULL

  8. #8
    Membre habitué Avatar de Sarrus
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Mai 2005
    Messages : 180
    Points : 138
    Points
    138
    Par défaut
    BOn j'ai des erreurs pour ma requete, quelqu'un peut me dire si la syntaxe, l'ordre est bon?

  9. #9
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 641
    Points
    4 641
    Par défaut
    Je crois que le where est entre le join et le group by

  10. #10
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Citation Envoyé par la_unge
    bon j'ai tenté la requete.... c'est bon au niveau syntaxe ?
    Non essaye :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT post_subject 
    FROM phpbb_posts a, phpbb_posts b, phpbb_posts_text, phpbb_forum 
    WHERE phpbb_posts.forum_id = phpbb_forum.forum_id 
    AND phpbb_posts.post_id = phpbb_posts_text.post_id 
    AND on a.time >= b.time
    AND post_subject NOT NULL
    GROUP BY phpbb_posts_text.post_subject, a.time
    HAVING COUNT(*) <= 5
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  11. #11
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    74
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 74
    Points : 74
    Points
    74
    Par défaut
    je ferais un ORDER BY sur les dates et j'introduirais un LIMIT 0,4
    Revérifie la syntaxe pour LIMIT mais il me semble que ca devrait te permettre de ne prendre que les 5 premiers éléments.

  12. #12
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Radium : LIMIT n'est pas dans la norme SQL et ne fonctionne pas avec tous les moteurs, avec ORACLE, c'est ROWNUM <= 5 qui fonctionnerait.

    php laisse penser que la base est mySQL, mais ce n'est pas obligatoire.
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

Discussions similaires

  1. afficher les 10 plus grandes valeurs
    Par logidev dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 17/06/2009, 09h25
  2. Récupérer les N plus grandes valeurs
    Par lloyd_r dans le forum MATLAB
    Réponses: 6
    Dernier message: 01/09/2008, 15h16
  3. determiner les 3 plus grandes valeurs numeriques du for-each
    Par makohsarah dans le forum Struts 1
    Réponses: 1
    Dernier message: 15/06/2008, 16h37
  4. trouver les 10 plus grandes valeurs
    Par audrey2112 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 16/11/2007, 11h30
  5. isoler les 2 plus grandes valeurs d'une liste
    Par marlene.ln dans le forum Access
    Réponses: 3
    Dernier message: 29/01/2007, 10h22

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