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 :

Maximum pour chaque groupe


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 30
    Points : 23
    Points
    23
    Par défaut Maximum pour chaque groupe
    Bonjour, je repasse ici car je rencontre encore sur un problème SQL.

    Le soucis est simple mais je connais mal le HAVING.


    En fait j'ai besoin de selectioner parmis une liste la plus grande valeur inférieur à la valeur que je donne par exemple j'ai deux tables :

    Table A :
    id
    1
    2
    3

    Table B :

    idB idA val
    1 1 1
    2 1 2

    3 2 1
    4 2 3
    5 2 4
    6 2 6

    7 3 1
    8 3 8
    9 3 9

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
        SELECT A.id, B.idB, B.val FROM A
        JOIN B on B.idA=A.id
        WHERE Bval<=4
        GROUP BY A.id
    ?????    HAVING MAX(val)  ?????

    Pour une valeur inferieur ou egale à 4, la requete que je souhaite devrait donc me retourner

    id idB val
    1 2 2
    2 5 4
    3 7 1

    (pour chaque id on prend la plus grande valeur inférieur à 4)

    En vous remerciant d'avance.

  2. #2
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Bonjour,

    Je pense que ceci devrait répondre à ton besoin :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     SELECT idA, max(val)
    FROM A JOIN B ON A.id = B.idA
    WHERE B.val <= 4
    GROUP BY idA
    ~ Lola ~

  3. #3
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 30
    Points : 23
    Points
    23
    Par défaut
    Dans l'esprit c'est ça mais je n'ai pas précisé que j'ai besoin d'autres champs liés à la plus grande valeur (que je n'ai pas indiqué dans mon select)

    Dans ton exemple ca me selectionne bien la plus grande valeur mais les autres champs ne changent pas !

  4. #4
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Tu peux l'utiliser en table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT * 
    FROM B 
    JOIN (
      SELECT idA, max(val)
      FROM A JOIN B ON A.id = B.idA
      WHERE B.val <= 4
      GROUP BY idA
    ) tmp
    ON tmp.idA = B.idA
    ~ Lola ~

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Octobre 2011
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2011
    Messages : 30
    Points : 23
    Points
    23
    Par défaut
    Merci pour ta solution, c'est exactement ce dont j'avais besoin !

    A bientôt

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

Discussions similaires

  1. ruban pour access 2007 pour chaque groupe de travail
    Par popofpopof dans le forum Access
    Réponses: 3
    Dernier message: 02/09/2007, 09h55
  2. Réponses: 9
    Dernier message: 30/07/2007, 17h56
  3. Les n premiers pour chaque groupe
    Par Sakalam dans le forum Langage SQL
    Réponses: 5
    Dernier message: 16/07/2007, 17h01
  4. Réponses: 13
    Dernier message: 06/07/2006, 12h25
  5. Récupérer les maximums pour chaque ensemble ?
    Par vynce dans le forum Langage SQL
    Réponses: 2
    Dernier message: 15/12/2005, 10h52

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