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 :

Séléctionner les plus grandes lignes


Sujet :

MySQL

  1. #1
    Membre habitué
    Profil pro
    Informaticien
    Inscrit en
    Juillet 2007
    Messages
    344
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations professionnelles :
    Activité : Informaticien

    Informations forums :
    Inscription : Juillet 2007
    Messages : 344
    Points : 127
    Points
    127
    Par défaut Séléctionner les plus grandes lignes
    Bonjour,

    Je sais pas trop comment expliquer ce que je voudrais faire, alors je vais monter un exemple...

    J'ai une table sql: contrat

    id - id_contrat - date_debut - date_fin
    1 - 1 - 2009-06-08 - 2010-06-07
    3 - 2 - 2008-06-09 - 2009-06-08
    4 - 2 - 2009-06-09 - 2010-06-08

    J'aimerais, avec une requête, qu'elle me retourne les lignes avec la date de fin (date_fin) la plus grande pour chaque "id_contrat"

    Donc théoriquement, j'aimerais arrivé a ce résultat :

    id - id_contrat - date_debut - date_fin
    1 - 1 - 2009-06-08 - 2010-06-07
    4 - 2 - 2009-06-09 - 2010-06-08

    J'essaye donc une requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT
    id,
    id_contrat,
    periode_debut,
    MAX(periode_fin) AS max_periode_fin
    FROM contrat
    GROUP BY id_contrat
    Cela me retourne le résultat suivant :

    id - id_contrat - periode_debut - max_periode_fin
    1 - 1 - 2009-06-08 - 2010-06-07
    3 - 2 - 2008-06-09 - 2010-06-08

    J'ai bien mes deux plus grandes dates pour chaque contrat, mais si on regarde l'id et date_debut à la ligne 2

    Cela est bien ce que je voulais, j'ai mes deux plus grande date pour chaque contrats.
    Mais voilà ou je veux en venir, si je compare la deuxième ligne du résultat avec la ligne qui possède la plus grande date dans la table contrat, je constate :

    Que la ligne qui a la plus grande date pour le contrat 2 est :

    id - id_contrat - date_debut - date_fin
    4 - 2 - 2009-06-09 - 2010-06-08

    Et la ligne qui est retourné après la requête :

    id - id_contrat - date_debut - date_fin
    3 - 2 - 2008-06-09 - 2010-06-08

    id et date_debut ne sont plus les mêmes

    Pourquoi cela ? Comment faire qu'il me retourne les lignes exactes ?

    Merci d'avance

  2. #2
    Membre régulier
    Profil pro
    None
    Inscrit en
    Mars 2008
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : None

    Informations forums :
    Inscription : Mars 2008
    Messages : 58
    Points : 80
    Points
    80
    Par défaut
    En gros, la logique à suivre serait du type:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SELECT
    id,
    id_contrat,
    periode_debut,
    periode_fin
    FROM contrat t1
    WHERE NOT EXISTS (
      SELECT 1
      FROM contrat t2
      WHERE t1.id_contrat = t2.id_contrat
      AND t1.periode_fin<t2.periode_fin
    )
    Par contre, si plusieurs contrats avec un même id_contrat finissent à la même date, cette requête te renverra toutes les lignes.

    A toi d'envisager les différents cas et de définir tes règles de priorité.

Discussions similaires

  1. Séléctionner les plus grandes lignes
    Par nesswaw dans le forum Langage SQL
    Réponses: 5
    Dernier message: 05/05/2010, 17h26
  2. requête pôur sélectionner les 5 valeurs les plus grandes ?
    Par kikidrome dans le forum Langage SQL
    Réponses: 7
    Dernier message: 06/11/2007, 16h29
  3. Réponses: 11
    Dernier message: 22/03/2007, 16h45
  4. Requete récupérer les 3 numéros les plus grands
    Par nerick dans le forum Langage SQL
    Réponses: 2
    Dernier message: 05/01/2006, 13h51
  5. afficher les plus grand montants
    Par bertrand_declerck dans le forum Langage SQL
    Réponses: 12
    Dernier message: 19/08/2005, 14h31

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