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 :

extraction minute a partir d'une date


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de habasque
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Septembre 2006
    Messages
    530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Septembre 2006
    Messages : 530
    Par défaut extraction minute a partir d'une date
    salut à tous,

    j'ai la formule ci-dessous qui doit me permettre de faire la différence entre 2 dates au format DD-MM-YYYY HH:MI:SS (AM ou PM).
    pour la différence entre "07-sept-2006 10:00 am" et "08-sept-2006 9:59 am" je souhaiterais obtenir "23:59:00" mais j'obtiens : "24:00:00"

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    WITH t AS (
    SELECT
    to_date(date_debut,'DD-MM-YYYY HH:MI:SS') d1,
    to_date(date_fin,'DD-MM-YYYY HH:MI:SS') d2,
    code_embarcation,
    numero_voyage,
    date_fin,
    date_debut
    FROM XIMARSIS.BIMV_CBITACORA)
     
     
    SELECT 
    code_embarcation,
    numero_voyage,
    date_fin,
    date_debut
    decode(sign(d2-d1),-1,'+')||
           to_char(abs(extract(day FROM ((d2 - d1) day TO second))*24 +
                extract(hour FROM ((d2 - d1) day TO second))),'FM999999900')||
      ':'||to_char(abs(extract(minute FROM ((d2 - d1) day TO second))),'FM00')||
      ':'||to_char(abs(extract(second FROM ((d2 - d1) day TO second))),'FM00')
    "D2-D1"
     
     
    FROM t
    si quelqu'un a une idée...

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 002
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 002
    Billets dans le blog
    6
    Par défaut
    TO_CHAR n'existe pas en SQL, Decode non plus. Postez votre requête dans un forum spécifique à votre SGBDR qui serait Oracle ???

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    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
    C'est dommage qu'oracle n'ait pas fait le format To_CHAR(date, 'HH10000'), mais ça se fait assez bien autrement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    WITH d AS ( 
    	SELECT TO_DATE('07.09.2006 10:00', 'DD.MM.YYYY HH24:MI') d1,
    		   TO_DATE('06.09.2006 10:00', 'DD.MM.YYYY HH24:MI') d2
    	FROM DUAL
    	)
    SELECT  SIGN(d2-d1)  * ( TRUNC(ABS(d2-d1)) * 24 + TO_NUMBER( TO_CHAR(TRUNC(SYSDATE) + ABS(d2 - d1), 'HH24'))) 
    		|| ':' || TO_CHAR(TRUNC(SYSDATE) + ABS(d2 - d1), 'MI:SS') AS heures
    FROM d
    EDIT 11h12 : Pas pensé aux horaires négatifs. Corrigé

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 18/03/2010, 08h57
  2. Comment extraire le mois à partir d'une date?
    Par toumoham dans le forum Paradox
    Réponses: 1
    Dernier message: 17/05/2006, 13h37
  3. [vbexcel]trouver le jour a partir d'une date.
    Par Mugette dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 08/12/2005, 16h07
  4. [D7] trouver une semaine partir d'une date
    Par raoulmania dans le forum Langage
    Réponses: 3
    Dernier message: 01/12/2005, 10h36
  5. Réponses: 3
    Dernier message: 19/04/2002, 00h11

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