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

Oracle Discussion :

Requête optimisée pour récupérer des enregistrements dans l'ordre chronologique


Sujet :

Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2006
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 10
    Points : 18
    Points
    18
    Par défaut Requête optimisée pour récupérer des enregistrements dans l'ordre chronologique
    Bonjour,

    Comment faire pour récupérer 999 enregistrement maximum lorsqu'une table en possède beaucoup plus. J'aimerai en plus que ces enregistrements soient les plus récent de la table. Voici la requête que j'utilise :
    select to_char(DATE_JOURNAL_H, 'YYYY/MM/DD HH24:MI:SS') from JOUR_H where NOM_UTILISATEUR like '%' and ROWNUM < 1000 order by DATE_JOURNAL_H DESC
    .
    Le problème de cette requête c'est que je n'ai pas les enregistrement les plus récent. QQ1 aurait une solution simple et optimal????????????????

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France, Haute Vienne (Limousin)

    Informations forums :
    Inscription : Octobre 2006
    Messages : 74
    Points : 95
    Points
    95
    Par défaut
    Il y a eu ce pb sur le forum il n'y a pas longtemps :

    Le rownum limite ta requête avant l'application de l'order by.
    Il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    select * from (select to_char(DATE_JOURNAL_H, 'YYYY/MM/DD HH24:MI:SS')
                        from JOUR_H
                        where NOM_UTILISATEUR like '%' order by DATE_JOURNAL_H DESC)
    WHERE ROWNUM < 1000;
    Mais ren fait je ne comprends pas l'intérêt de ton
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where NOM_UTILISATEUR like '%'
    Si tu veux tout le monde, fait plutôt :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select * from (select to_char(DATE_JOURNAL_H, 'YYYY/MM/DD HH24:MI:SS')
                                from JOUR_H order by DATE_JOURNAL_H DESC)
    WHERE ROWNUM < 1000;

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

Discussions similaires

  1. [XL-2007] Macro pour récupérer des noms dans un onglet
    Par Nahtalie dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 30/04/2013, 15h07
  2. Réponses: 2
    Dernier message: 21/05/2011, 13h30
  3. Réponses: 4
    Dernier message: 29/03/2011, 17h13
  4. Requête HTTP pour récupérer des quotations.
    Par Pierre8r dans le forum Développement Web en Java
    Réponses: 2
    Dernier message: 18/01/2008, 16h41
  5. Réponses: 6
    Dernier message: 28/12/2007, 22h34

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