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

Développement SQL Server Discussion :

Sélection de l’enregistrement le plus récent


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 562
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 562
    Par défaut Sélection de l’enregistrement le plus récent
    Bonjour j'ai une table de ce style

    date tag value
    2010-10-10 11:24:00.000 A 5
    2010-10-10 11:25:00.000 A 10
    2010-10-10 11:32:00.000 B 20
    2010-10-10 12:02:00.000 A 30
    2010-10-10 12:06:00.000 B 40

    et j'aimerais récupérer la valeur a la date la plus grande (inférieur ou égale a une date)..
    donc j'ai fait ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select *
    from xx
    inner join 
    (SELECT xx.tag as t, 	  
    	  MAX(xx.date) as d
      FROM xx
      Where xx.date <= '2010/10/10 11:32:00'
      group by xx.tag) a
    on a.t = xx.tag and a.d = xx.date
    order by XX.tag
    ce qui me donne

    date tag value t d
    2010-10-10 11:25:00.000 A 10 A 2010-10-10 11:25:00.000
    2010-10-10 11:32:00.000 B 20 B 2010-10-10 11:32:00.000

    et c'est bien mon résultat attendu

    bref j'aimerais savoir si il n'y aurait pas une écriture plus simple (plus sexy)
    si vous avez une idée

    merci

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 002
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 002
    Billets dans le blog
    6
    Par défaut
    Plein de façon...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select *, (SELECT MAX(xx.date) as d
               FROM   xx 
               WHERE  xx.tag = y.tag) AS dmax 	  
    from xx AS y
    WHERE  xx.date <= '2010/10/10 11:32:00'
    HAVING xx.date >= dmax 
    order by XX.tag
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 562
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 562
    Par défaut
    merci,
    je me doute
    je pensais plus a une clause select unique sans select imbriqué

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 622
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 622
    Billets dans le blog
    10
    Par défaut
    Bonjour Ikeas

    Vous trouverez plusieurs solutions à ce type de questions dans mon blog ici :
    https://www.developpez.net/forums/bl...cente-critere/

  5. #5
    Membre Expert
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    1 562
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 562
    Par défaut
    merci ....

Discussions similaires

  1. [AC-2016] Problème sélection de l'enregistrement le plus récent
    Par Pygmalion37 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 25/10/2016, 14h34
  2. Réponses: 5
    Dernier message: 25/01/2008, 20h26
  3. Ne conserver que les N enregistrement les plus récents.
    Par gomodo dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/01/2008, 19h46
  4. Trouver l'enregistrement le plus récent
    Par PrinceMaster77 dans le forum Langage SQL
    Réponses: 8
    Dernier message: 19/02/2005, 19h14
  5. recup des enregistrement les plus récents.
    Par julien_guy dans le forum Langage SQL
    Réponses: 8
    Dernier message: 29/06/2004, 11h04

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