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

Développement SQL Server Discussion :

Converstion Timestamp en milliseconde en date visible


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Novembre 2007
    Messages
    154
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 154
    Par défaut Converstion Timestamp en milliseconde en date visible
    Bonjour,

    Je cherche à transformer un timestamp en une date lisible. Le soucis c'est que le timestamp est en millisecondes. si je le divise par 1000 ça fonctionne bien en utilisant la fonction DATEADD mais je perds la précision des millisecondes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT DATEADD(SECOND, 1408324137459/1000, CAST('1970-01-01 00:00:00.0000000' AS datetime2))
     
    2014-08-18 01:08:57.0000000
    J'ai testé en faisant un DATEADD MILLISECOND mais j'ai un message d'erreur de dépassement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT DATEADD(MILLISECOND, 1408324137459, CAST('1970-01-01 00:00:00.0000000' AS datetime2))
     
    Msg 8115, Level 16, State 2, Line 1
    Arithmetic overflow error converting expression to data type int.
    Comment faire ?

  2. #2
    Membre émérite Avatar de GeekMokona
    Femme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2011
    Messages
    327
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 45
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2011
    Messages : 327
    Par défaut
    Une des solutions est de partir de ta première requête en y rajoutant les millisecondes

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATEADD(MILLISECOND,1408324137459%1000,DATEADD(SECOND, 1408324137459/1000, CAST('1970-01-01 00:00:00.0000000' AS datetime2)))

  3. #3
    Membre confirmé
    Inscrit en
    Novembre 2007
    Messages
    154
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 154
    Par défaut
    Super

    Comme d'habitude il suffisait d'y penser

    Merci

  4. #4
    Membre Expert

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Septembre 2003
    Messages
    733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2003
    Messages : 733
    Billets dans le blog
    8
    Par défaut
    N'oubliez pas que si la précision que vous voulez atteindre ne dépasse pas le milliseconde , vous devez utiliser datetime2(3) au lieu de datetime2 (équivalent à datetime2(7), 7 étant la précision par défaut)

    datetime2(3) occupe 6 octets alors datetime2 (= datetime2(7)) occupe 7 octets.

    Il y a un octet de différence, ce n'est certes pas beaucoup, mais sur plusieurs millions d'enregistrements cela peut faire la différence (nombre d'enregistrements (lignes) dans une page de données ou d'index etc.. )

    Donc, si vous devez stocker ces données dans une tables optez plutôt pour le type datetime2(3).

    De même la requête de mokona18 (très juste par ailleurs) peut être légèrement transformée pour retourner une valeur du type datetime2(3).

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DATEADD(MILLISECOND, 1408324137459%1000, CAST(DATEADD(SECOND, 1408324137459/1000, CAST('1970-01-01 00:00:00' AS datetime2(0))) AS  datetime2(3) ))
    Résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    2014-08-18 01:08:57.459
    A+

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/06/2010, 12h37
  2. oracle conversion de millisecondes en date
    Par grospatapouf dans le forum Débuter
    Réponses: 1
    Dernier message: 09/06/2009, 16h12
  3. Réponses: 18
    Dernier message: 22/06/2007, 15h42
  4. [javascript]Nombre de 13 chiffre (millisecondes) en date
    Par lunart dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 22/01/2007, 10h29
  5. [SQL] un champ Timestamp ou deux champs Date et Heure?
    Par davmaster62 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 25/02/2006, 23h04

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