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 :

Trier à l'intérieur d'une table avec GROUP BY ?


Sujet :

Langage SQL

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Autriche

    Informations forums :
    Inscription : Janvier 2011
    Messages : 8
    Points : 5
    Points
    5
    Par défaut Trier à l'intérieur d'une table avec GROUP BY ?
    bonjour,

    je tourne un peu en rond. j'ai une table de ce type

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    markets
    id - commune - poids
    1 - 11 - 111
    2 - 22 - 222
    3 - 22 - 333
    4 - 33 - 444
    en gros je veux avoir une ID de "markets" unique pour toutes les communes et de celles-ci celle avec le plus grand poids. donc

    en travaillant avec DISTINCT je ne peux pas trier et avec GROUP BY je perd mes IDs...


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT
        commune, max(poids), count(*)
    FROM
        markets
    GROUP BY
        commune
    me donne bien la bonne valeur pour "poids" et le nombre d'occurences par commune, mais pas l'ID car elle devrait être incluse dans GROUP BY pour cela.

    je suis sous postgresql mais cela ne devait rien changer à mon problème de nœud dans la tête... quelqu'un aurait une idée légère en matière de demande à la BD?

    merci pour les tuyaux,
    andré

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    sur le principe :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    SELECT 
         markets.id
      ,  markets.Commune
      ,  markets.Poids
    FROM markets 
    INNER JOIN (
        SELECT Commune, MAX(Poids) MaxPoids
        FROM Markets
        GROUP BY Commune
    ) M
        ON M.Commune = markets.Commune
        AND M.MaxPoids = markets.Poids
    Mais si une commune à deux fois le même poids max, elle ressortira deux fois

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Autriche

    Informations forums :
    Inscription : Janvier 2011
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    merci beaucoup aieeeuuuuu,

    cela m'avance vraiment. merci aussi d'indiquer qu'il reste des doublons à cause du JOIN. je viens de jouer un peu et j'ai trouvé ça pour les enlever aussi:


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT 
         DISTINCT ON (markets.Poids) markets.Poids
      ,  markets.id
      ,  markets.Commune 
    FROM markets 
    INNER JOIN (
        SELECT Commune, MAX(Poids) MaxPoids
        FROM Markets
        GROUP BY Commune
    ) M
        ON M.Commune = markets.Commune
        AND M.MaxPoids = markets.Poids
    petit défaut: on ne peut plus faire de ORDER BY sur une autre colonne que markets.Poids.

    pour ce faire on pourrait s'y prendre comme ça mais je ne sais pas si c'est efficace:

    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
     
    SELECT * FROM (
      SELECT 
         DISTINCT ON (markets.Poids) markets.Poids
      ,  markets.id
      ,  markets.Commune 
      FROM markets 
      INNER JOIN (
        SELECT Commune, MAX(Poids) MaxPoids
        FROM Markets
        GROUP BY Commune
      ) M
        ON M.Commune = markets.Commune
        AND M.MaxPoids = markets.Poids
    ) AS sub
    ORDER BY sub.id

  4. #4
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Citation Envoyé par a666a666 Voir le message
    petit défaut: on ne peut plus faire de ORDER BY sur une autre colonne que markets.Poids.
    Ben il semble suffire de faire un http://www.postgresql.org/docs/9.0/s...ql-select.html

    Sinon en fonction de la version de postgresql utilisée, je passerais plutôt par une fonction analytique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select id, commune, poids
      from (
    select id, commune, poids, row_number() over (partition by commune order by poids desc, id) as rn
      from markets
           ) t
     where rn = 1

Discussions similaires

  1. [1.x] filter une table avec un groupe
    Par nlefebvre1 dans le forum Symfony
    Réponses: 1
    Dernier message: 25/11/2011, 11h22
  2. Réponses: 3
    Dernier message: 18/02/2009, 19h00
  3. [MySQL] Lecture d'une table avec requête ordonnée et groupée
    Par kabkab dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 24/06/2008, 15h38
  4. [Access] Nom d'une table avec un espace dans SQL
    Par Corsaire dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/04/2006, 16h50
  5. Trier une table avec valeur de differentes unités
    Par Sydaze dans le forum Bases de données
    Réponses: 8
    Dernier message: 01/06/2005, 12h43

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