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 :

Petit problème SQL


Sujet :

Langage SQL

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

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 17
    Points
    17
    Par défaut Petit problème SQL
    Bonjour

    Je me pose la question de savoir comment récupérer la valeur maximale d'une ligne.
    Je vais m'expliquer :

    J'ai une table qui contient des informations dont une date de création de la ligne d'information. Chaque ligne correspond à 1 employé mais il peut y avoir plusieurs lignes pour 1 employé.
    Je voudrais récupérer une seul ligne par employé, cette ligne étant celle qui a la date de création la plus grande.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT NUMEMPLOYE, VALEUR, DATECREATION FROM MATABLE
    Cette requete me renvoie par exemple :
    "055", "VALEURAA", "10/12/2013"
    "055", "VALEURBB", "14/01/2014"

    Et donc je voudrais récupérer seulement la valeur BB.


    Merci d'avance pour votre aide précieuse

  2. #2
    Membre confirmé
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2009
    Messages
    339
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2009
    Messages : 339
    Points : 586
    Points
    586
    Par défaut
    Tout dépend du SGBD utilisé...
    En Oracle il faudra une fonction analytique, en MySQL, un MAX..

  3. #3
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 188
    Points : 12 744
    Points
    12 744
    Par défaut
    Bonjour,
    On peut aussi utiliser une jointure:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select t1.*
    from LaTable t1
    left outer join LaTable t2 on t1.id = t2.id and t2.date > t1.date
    where t2.id is null

    Tatayo.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    Oui pardon j'ai oublié de précisé, c'est du HyperFileSQL
    C'est très similaire à MySQL (pour ceux qui ne connaissent pas).

    Avec un max j'ai essayé mais je ne trouve pas la bonne formule...

    Tatayoyo merci pour ton aide. Le problème avec ce que tu m'as donné est que les personnes qui n'ont qu'une seule ligne ne sont pas récupérées...

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

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Citation Envoyé par Yooo84 Voir le message
    Avec un max j'ai essayé mais je ne trouve pas la bonne formule...
    Regardez par exemple ce post pour mysql :
    http://www.developpez.net/forums/d12...ect-count-max/

  6. #6
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    Merci skuatamad pour ta réponse.

    Le problème est le même qu'avec la solution de tatayoyo.

    C'est-à-dire que les personnes qui n'ont qu'une seule ligne ne sont pas gardées.

    Si je reprends mon exemple avec

    "055", "VALEURAA", "10/12/2013"
    "055", "VALEURBB", "14/01/2014"
    "056", "VALEURAA", "10/12/2013"
    "057", "VALEURAA", "10/12/2013"
    Je voudrais que ma requête me renvoie :
    "055", "VALEURBB", "14/01/2014"
    "056", "VALEURAA", "10/12/2013"
    "057", "VALEURAA", "10/12/2013"
    Et non pas seulement :
    "055", "VALEURBB", "14/01/2014"
    Vous comprenez ?

  7. #7
    Membre expérimenté
    Avatar de islamov2000
    Homme Profil pro
    Ingénieur d'études & developpement en informatique
    Inscrit en
    Septembre 2007
    Messages
    814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur d'études & developpement en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2007
    Messages : 814
    Points : 1 717
    Points
    1 717
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select A.* from test A join 
    (select NUMEMPLOYE,max(DATECREATION)DATECREATION from test
    group by NUMEMPLOYE)B on A.NUMEMPLOYE=B.NUMEMPLOYE and A.DATECREATION=B.DATECREATION
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    NUMEMPLOYE  VALEUR         DATECREATION
    055               VALEURBB    14/01/2014
    056               VALEURAA    10/12/2013
    057               VALEURAA    10/12/2013
    Bonne chance
    d'avoir Pensé à voter positivement pour ceux qui vous ont aidés et surtout à mettre si le cas.
    ça encourage.

  8. #8
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2012
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    Yes merci à vous tous pour votre aider.
    Prompt et réactif, j'aime ce forum je vais essayer de plus m'investir pour aider d'autres "collegues"

  9. #9
    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,

    Comment avez vous implémenté la solution de tatayo ? elle me semble pourtant correcte !

  10. #10
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 188
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 188
    Points : 12 744
    Points
    12 744
    Par défaut
    Je pense que le problème vient en fait du moteur (ici HF).
    Suivant la version, le support des jointures externes est... approximatif dirais-je

    Tatayo.

  11. #11
    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
    Citation Envoyé par tatayo Voir le message
    Suivant la version, le support des jointures externes est... approximatif dirais-je

    Tatayo.
    ouchhh

    à ce point là ???
    Les données qui sont à l'autre bout du plateau sur le disque, le SGBD a la flemme d'aller les chercher ?

    Citation Envoyé par tatayo Voir le message
    approximatif
    Là, c'est vraiment le politiquement correct poussé à son paroxysme !

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

Discussions similaires

  1. Petit problème SQL
    Par kisama dans le forum Requêtes
    Réponses: 2
    Dernier message: 20/08/2012, 21h15
  2. Petit problème SQL
    Par Mushi dans le forum Langage SQL
    Réponses: 6
    Dernier message: 17/04/2008, 16h50
  3. Petit problème avec une requête SQL en VB6
    Par muzele dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 15/11/2007, 21h51
  4. Petit problème sql très embetant
    Par FataL_KilleR dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/07/2007, 12h35
  5. Petit problème SQL (GROUP BY|ORDER BY)
    Par kalash_jako dans le forum Langage SQL
    Réponses: 4
    Dernier message: 10/04/2007, 00h17

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