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

SQL Oracle Discussion :

comparaison de dates


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 23
    Par défaut comparaison de dates
    Bonjour,

    J'ai une table qui s'enrichit au fil du temps d'informations et qui possède une colonne LAST_UPDATE_DATE

    Je cherche à comparer le max(LAST_UPDATE_DATE) avec sysdate pour trouver combien d'enregistrements ont un LAST_UPDATE_DATE inférieur à 4h...

    Pouvez-vous m'aider ?

  2. #2
    Rédacteur
    Avatar de jsd03
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2008
    Messages
    1 221
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2008
    Messages : 1 221
    Par défaut
    Bonjour,

    Sachant que si tu fais sysdate - LAST_UPDATE_DATE le résultat te retournera un nombre de jour il suffit de multiplier le tout par 24 et tu auras ton résultat en nombre d'heure et tu pourras ainsi prendre uniquement les résultats inférieurs à 4 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT *
    FROM maTable
    WHERE (sysdate - LAST_UPDATE_DATE)*24 > 4
    Cela répond à ta question ?
    Google est ton ami mais ton voisin aussi

    Modérateur BI - Responsable Talend
    Mes tutoriels - FAQ Talend - FAQ SQL*Plus

    Avant toute chose : lire le mode d'emploi du forum et ses règles.
    Suivez @Developpez sur twitter !

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 23
    Par défaut
    Merci pour ta piste

    Par contre, quand je consulte les derniers enregistrements de la table, j'obtiens :

    [...]
    16-MAR-2009 06:37:43
    16-MAR-2009 07:04:07
    16-MAR-2009 07:04:07
    16-MAR-2009 07:10:21
    16-MAR-2009 07:10:21
    16-MAR-2009 07:28:18
    16-MAR-2009 07:28:18
    16-MAR-2009 07:39:47
    16-MAR-2009 07:39:47
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46
    16-MAR-2009 07:42:46

    SQL> select to_char(sysdate,'DD-MON-YYYY HH24:MI:SS') from dual;

    TO_CHAR(SYSDATE,'DD-
    --------------------
    16-MAR-2009 11:49:05

    Donc logiquement, en faisant :

    SQL> select count(*) from ... where (sysdate - LAST_UPDATE_DATE)*24 > 4

    Je devrais obtenir 0, or j'obtiens 418

  4. #4
    Rédacteur
    Avatar de jsd03
    Homme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Août 2008
    Messages
    1 221
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Août 2008
    Messages : 1 221
    Par défaut
    Excuse moi j'ai mis supérieur à 4 au lieu d'inférieur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT *
    FROM maTable
    WHERE (sysdate - LAST_UPDATE_DATE)*24 < 4
    Ca va mieux là du coup ?
    Google est ton ami mais ton voisin aussi

    Modérateur BI - Responsable Talend
    Mes tutoriels - FAQ Talend - FAQ SQL*Plus

    Avant toute chose : lire le mode d'emploi du forum et ses règles.
    Suivez @Developpez sur twitter !

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 23
    Par défaut
    Effectivement ça paraît plus logique avec <

    Par contre, j'ai toujours un résultat bizarre 98

    Es-tu sûr de la multiplication par 24 ???

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 23
    Par défaut
    Citation Envoyé par mevardy Voir le message
    Effectivement ça paraît plus logique avec <

    Par contre, j'ai toujours un résultat bizarre 98

    Es-tu sûr de la multiplication par 24 ???
    Laisses tomber c'est moi qui ne suit pas bien réveillé ce matin

    Ca marche nickel


  7. #7
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    sysdate - 1/6 (sysdate il y a quatre heures)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SQL> 
    SQL> select to_char(sysdate,'DD-MON-YYYY HH24:MI:SS'), to_char(sysdate - 1/6,'DD-MON-YYYY HH24:MI:SS')
      2  from dual
      3  /
     
    TO_CHAR(SYSDATE,'DD-MON-YYYYHH TO_CHAR(SYSDATE-1/6,'DD-MON-YY
    ------------------------------ ------------------------------
    16-MAR-2009 11:56:35           16-MAR-2009 07:56:35
    donc where last_update_date > sysdate - 1/6

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

Discussions similaires

  1. comparaison de dates javascript
    Par SpaceFrog dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 12/07/2005, 08h45
  2. comparaison de dates
    Par pmithrandir dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 02/06/2005, 16h12
  3. comparaison de date
    Par nickoshiba dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 15/03/2005, 15h48
  4. Comparaison de dates
    Par Tapioca dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 16/06/2004, 15h55
  5. Problème de comparaison de dates
    Par MiJack dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/03/2004, 21h43

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