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 :

Différence entre deux dates


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mars 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2012
    Messages : 2
    Par défaut Différence entre deux dates
    J'ai un petit soucis pour trouver la différence entre une date et une heure d'entrée et une date et une heure de sortie.
    Petite difficulté : date entreé, date sortie, heure entrée et heure sortie => varchar2.
    au format : DD/MM/YYYY et HH:MI

    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
    select
    nom,
    prenom,
    (to_date(date_entree||' '||heure_entree,'DD/MM/YYYY HH24:MI')) as "date entree",
    (to_date(date_sortie||' '||heure_sortie,'DD/MM/YYYY HH24:MI')) as "date de sortie",
    ((to_date(date_sortie||' '||heure_sortie,'DD/MM/YYYY HH24:MI')) - (to_date(date_entree||' '||heure_entree,'DD/MM/YYYY HH24:MI')))*24 as "difference"
    from
    multicol
    where
    to_date(date_entree,'DD/MM/YYYY') between '20/02/2012' and '29/02/2012' 
    and date_sortie is not null
     
     
    NOM   | PRENOM   |date entree         | date de sortie     |difference
    TOTO		TITI			20/02/2012 14:57:00   21/02/2012 02:11:00 11,2333333333
    comment faire pour avoir : 11H14 ?? au lieu de 11.233333

    Merci

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Essayez comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT nom
         , prenom
         , to_date(date_entree || ' ' || heure_entree, 'DD/MM/YYYY HH24:MI') AS "date entree"
         , to_date(date_sortie || ' ' || heure_sortie, 'DD/MM/YYYY HH24:MI') AS "date de sortie"
         , to_char(trunc(sysdate)
         + (to_date(date_sortie || ' ' || heure_sortie, 'DD/MM/YYYY HH24:MI')
         -  to_date(date_entree || ' ' || heure_entree, 'DD/MM/YYYY HH24:MI')), 'HH:MI') AS "difference"
      FROM multicol
     WHERE to_date(date_entree,'DD/MM/YYYY') BETWEEN to_date('20/02/2012', 'dd/mm/yyyy')
                                                 AND to_date('29/02/2012', 'dd/mm/yyyy')
       AND date_sortie IS NOT NULL;

  3. #3
    Candidat au Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mars 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2012
    Messages : 2
    Par défaut
    Merci !
    ça fonctionne, j'avais pourtant "trituré" le "to_char(trunc)" dans tous les sens, mais sans succès.
    Je m'apprêtais à faire une fonction...ceci est beaucoup plus léger.

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Une mise en garde toutefois, cette astuce s'arrête à 24h d'écart entre le début et la fin :
    Sinon vous pouvez regarder du côté des intervalles :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select to_char(trunc(sysdate) + (to_date(date_sortie, 'DD/MM/YYYY HH24:MI') - to_date(date_entree, 'DD/MM/YYYY HH24:MI')), 'HH:MI') as df1
         , numtodsinterval(to_date(date_sortie, 'DD/MM/YYYY HH24:MI') - to_date(date_entree, 'DD/MM/YYYY HH24:MI'), 'DAY') as df2
      from (select '19/02/2012 14:57' as date_entree, '21/02/2012 02:11' as date_sortie from dual);
     
    DF1   DF2       
    ----- -----------
    11:14 1 11:14:0.0

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/07/2006, 14h04
  2. Nombre de minutes de différence entre deux dates
    Par Oberown dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 05/05/2006, 15h41
  3. Différence entre deux dates
    Par Azharis dans le forum Access
    Réponses: 3
    Dernier message: 11/01/2006, 10h58
  4. Différence entre deux dates
    Par pittzz dans le forum Oracle
    Réponses: 5
    Dernier message: 18/07/2005, 12h24
  5. Comment obtenir la différence entre deux dates ?
    Par jbat dans le forum Langage
    Réponses: 4
    Dernier message: 02/06/2005, 09h34

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