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 :

Ne conserver que les N enregistrement les plus récents.


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Points : 121
    Points
    121
    Par défaut Ne conserver que les N enregistrement les plus récents.
    Bonsoir à tous,

    J'ai une table dans laquelle il y a un champs "date d'enregistrement".

    Comment traduire en SQL la phrase suivante :

    "Ne conserver que les N enregistrement les plus récents."

    En réalité, il faut raisonner à l'inverse, puisque en pratique il s'agit de faire un DELETE.

    Donc, si je "Ne conserve que les N enregistrement les plus récents." alors je doit "supprimer ... heu ...bin "

  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
    21 772
    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 : 21 772
    Points : 52 737
    Points
    52 737
    Billets dans le blog
    5
    Par défaut
    Utilisez une fonction de fenêtrage pour ce faire :

    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
    CREATE TABLE T (D DATETIME)
     
    INSERT INTO T VALUES ('20010101')
    INSERT INTO T VALUES ('20020101')
    INSERT INTO T VALUES ('20030101')
    INSERT INTO T VALUES ('20040101')
    INSERT INTO T VALUES ('20050101')
    INSERT INTO T VALUES ('20060101')
    INSERT INTO T VALUES ('20070101')
    INSERT INTO T VALUES ('20080101')
     
    DELETE FROM T
    WHERE  D IN (SELECT D
                 FROM   (SELECT ROW_NUMBER() OVER (ORDER BY D DESC) AS N, *
                         FROM   T) AS T
                 WHERE  N > 5)
    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 régulier
    Inscrit en
    Mai 2007
    Messages
    183
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 183
    Points : 121
    Points
    121
    Par défaut
    Merci SQLPro.

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 26/06/2008, 23h43
  2. Réponses: 5
    Dernier message: 02/05/2008, 15h28
  3. Réponses: 5
    Dernier message: 25/01/2008, 20h26
  4. Réponses: 3
    Dernier message: 28/11/2003, 21h26

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