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 :

Soustraction de deux dates pour obtenir un nombre de minutes


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Technicien Help Desk

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Par défaut Soustraction de deux dates pour obtenir un nombre de minutes
    Bonjour,

    J'aimerai si possible trouver le nombre de minutes entre deux heures.

    Dans mon exemple :
    hdeb_prev : 30/12/99 - 08:46 (l'année 99 n'est pas une erreur)
    hdeb_reel : 02/01/20 - 09:06

    Je m'explique, j'ai deux dates (date_heure_prevu et date_heure_reel), avec seulement les heures/minutes/secondes de significatifs (stocké au format 'date'), et lorsque je fais ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (hdeb_prev - hdeb_reel) * 60 * 60 * 24
    J'ai ce résultat : -3787086000

    A cause de l'année 99 je pense...

    Quelqu'un peux-il-m'aider ?

    Merci à tous.

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Année 99 de quelle siècle ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    to_char(hdeb_prev, 'DD/MM/YYYY HH24:MI:SS')
    voire, j'ai déjà eu le cas dans le forum avec une date en BC
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    to_char(hdeb_prev, 'DD/MM/SYYYY HH24:MI:SS')

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Technicien Help Desk

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Par défaut
    Bonjour,

    Voila mon résultat : 30/12/18999 08:46:00

    Année 18999 (!)

    Merci pour ton aide je n'y arrive toujours pas

  4. #4
    Membre Expert
    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Décembre 2019
    Messages
    1 175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Décembre 2019
    Messages : 1 175
    Par défaut
    Bonjour,

    Tu n'as pas le siècle de ta date, cela veut dire que tes dates ne sont pas stockées avec le type DATE?
    Même si on suppose 2099 et 2020, quel est l'intérêt d'avoir le nombre de minutes écoulées entre tant d'années?

    Il faut simplement faire : 24 * 60 * (date_fin - date_debut)

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Technicien Help Desk

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Par défaut
    Bonjour,

    Merci pour ton aide.

    Lorsque je fais cette solution :

    24 * 60 * (hdeb_prev - hdeb_reel)
    (30/12/18999 - 08:46) - (02/01/2020 - 09:06)

    Voici le résultat :
    -63118100,00000000000000000000000000000002

    Le résultat que je souhaite ce serait d'avoir le temps écoulé qui est 20 min, seulement la différence entre les deux heures.

    Je sais pas si je suis très clair dans ma demande...

  6. #6
    Membre Expert
    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Décembre 2019
    Messages
    1 175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Décembre 2019
    Messages : 1 175
    Par défaut
    Oui c'est plus clair. Si tu veux juste le nombre de minutes alors fait:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select 24*60*
           abs(to_date(to_char(hdeb_prev , 'hh24:mi'), 'hh24:mi') 
          - to_date(to_char(hdeb_reel, 'hh24:mi'), 'hh24:mi')) 
    from dual;
    Cela suppose que hdeb_prev et hdeb_reel sont de types DATE. Sinon de quels types sont-ils?

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 31/05/2012, 23h42
  2. Réponses: 5
    Dernier message: 26/05/2009, 17h54
  3. Réponses: 8
    Dernier message: 29/09/2006, 18h09
  4. Soustraction entre deux dates
    Par franculo_caoulene dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 20/01/2006, 10h59
  5. [Date] Soustraction de deux dates ?
    Par Invité dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 29/03/2004, 11h54

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