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

PL/SQL Oracle Discussion :

pb avec systimestamp


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mars 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 86
    Par défaut pb avec systimestamp
    Bonjour,

    J'ai une colonne de type Date sous le format dd/mm/yyyy HH24:MI:SS. Qd j'inserre une valeur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TO_CHAR(sysdate,'DD/MM/YYYY HH24:MI:SS')
    ça marche bien.
    Par contre, mon but est d'afficher les millisecondes, j'utilise la req suivante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     TO_CHAR(systimestamp,'DD/MM/YYYY HH24:MI:SS.FF')
    mais ça marche pas.
    Seriez-vous d'où vient de pb?

    Merci

  2. #2
    Membre chevronné Avatar de xdescamp
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 300
    Par défaut
    Bonjour,

    Si la colonne est de type DATE, c'est une date, point, il n'y a pas de format.
    Du coup, ça ne sert à rien de faire un TO_CHAR(SYSDATE,....), ça ne peut apporter que des erreurs. Il suffit d'insérer directement SYSDATE.

    Pour répondre à votre question, SYSTIMESTAMP ne retourne pas un type DATE (dont la précision s'arrête à la seconde), mais un type TIMESTAMP dont la précision va à la millisconde.
    Il faut donc changer le type de votre colonne de DATE à TIMESTAMP.

  3. #3
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par xdescamp Voir le message
    SYSTIMESTAMP ne retourne pas un type DATE (dont la précision s'arrête à la seconde), mais un type TIMESTAMP dont la précision va à la millisconde.
    La précision peut même aller jusqu'à la nanoseconde...

  4. #4
    Membre confirmé
    Inscrit en
    Mars 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 86
    Par défaut
    J'ai modifié la type de ma col en timestamp
    je fais la req suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    update matable set (debut) = 
    (select TO_char(systimestamp,'MM/DD/YYYY HH24:MI:SS:FF3') from dual)
    where message_type = 'test'
    mais j'ai l'erreur : ORA-01830: date format picture ends before converting entire input string

  5. #5
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    Bonjour,

    bah non ,

    Si ta colonne est timestamp tu ne peux faire un to_char pour insérer dedans !

    le to_char c'est pour formatter la sortie de la selection apres

    Par contre to_timestamp pour insérer ...

    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
     
     >create table c4 (col1 timestamp);
     
    >insert into c4 values (systimestamp);
     
    > SELECT TO_CHAR(systimestamp,'MM/DD/YYYY HH24:MI:SS:FF3') "Date" FROM dual;
     
    Date
    -----------------------------
    09/07/2009 15:30:29:340
     
     
    > insert into c4  select to_timestamp('2009/09/08 10:00:00', 'YYYY/MM/DD HH:MI:SS') from dual;
     
    1 row created.
     
    >

  6. #6
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    Bonjour,

    tu peux essayer

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT TO_CHAR(systimestamp,'MM/DD/YYYY HH24:MI:SS:FF3') "Date" FROM dual;
     
    Date
    -----------------------------
    09/02/2009 17:55:42:058

  7. #7
    Membre confirmé
    Inscrit en
    Mars 2009
    Messages
    86
    Détails du profil
    Informations forums :
    Inscription : Mars 2009
    Messages : 86
    Par défaut
    Enfaite j'ai pas la possibilité de modifier le type de la colonne.
    y'a t-il un autre moyen?

    Merci

  8. #8
    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
    Et bien non, le format DATE chez Oracle s'arrête à la seconde.
    Ou alors vous sortez votre date en chaîne de caractère et vous concaténez trois zéros, mais bon, c'est pas terrible :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select to_char(sysdate,'DD/MM/YYYY HH24:MI:SS') || '.000' from dual

Discussions similaires

  1. requete avec OBCD et visual c++
    Par Anonymous dans le forum MFC
    Réponses: 12
    Dernier message: 18/11/2004, 16h15
  2. [langage] Comparer Perl avec d'autres langages comme C ?
    Par Anonymous dans le forum Langage
    Réponses: 3
    Dernier message: 10/08/2002, 23h52
  3. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10
  4. [Kylix] Runtime error 230 avec INDY
    Par Anonymous dans le forum EDI
    Réponses: 2
    Dernier message: 23/03/2002, 11h51
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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