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

  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 167
    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 167
    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 167
    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 167
    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?

  7. #7
    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
    Euh, en fait j'avais mis un Y en trop en recopiant

    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')
    Donc ta date est en 1899

  8. #8
    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
    Quand tu dis que tu veux juste avoir la durée entre les heures, peux-tu avoir un cas où les jour changent exemple 23h59 - 01h05 ?
    Dans ce cas, ça va être plus compliqué à gérer sans gérer les jours.

  9. #9
    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
    Merci à vous pour ces réponses.

    Mes deux champs sont bien de type DATE.

    Toutes mes dates sont effectivement au 30/12/1899 à ma connaissance. Il y a juste l'heure qui change.

    Pour que mon résultat soit sur 2 décimal comment puis-je faire ?

  10. #10
    Membre Expert
    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Décembre 2019
    Messages
    1 167
    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 167
    Par défaut
    Utilise la fonction ROUND(ta_valeur, 2)

  11. #11
    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
    Merci à tous ça fonctionne

+ 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