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

MS SQL Server Discussion :

[Compact v3.5]Troncature d'une date


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de méphistopheles
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 551
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 551
    Par défaut [Compact v3.5]Troncature d'une date
    Bonjour.

    Suite à ce problème, j'ai été amené à vouloir comparer une date en deux morceaux, c'est à dire les année/jours/heures et les minutes/secondes/milisecondes.

    Le problème de la troncature s'est alors posé.

    J'ai lu dans ce post qu'il fallait pour cela convertir la date en char puis à nouveau en date.
    J'ai donc essayé cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT
        cast(convert(nvarchar(10),[SyncTime],103)as datetime),
        cast(convert(nvarchar(8),[SyncTime],108)as datetime)
    FROM
      [Suppliers]
    et effectivement, cela fonctionne correctement.

    Cependant, je ne comprend pas du tout comment cela fonctionne (ce qui m'ennuie), mais surtout, j'ai lu que cette méthode n'était pas robuste ici (ce n'est pas forcément une référence, mais j'aimerais savoir pourquoi).

    Pourriez-vous m'éclairer sur le sujet ?

    D'autre part, le découpage que je voudrais faire serait plutot MM/DD/YYYY HH d'un coté et nn:ss:ms de l'autre. or ici, on ne peut faire que daytime et date et on ne peut avoir les milisecondes.

    Bref, si vous avez une idée...

    Merci d'avance

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 228
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 228
    Billets dans le blog
    25
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT
       cast(convert(char(13), [SyncTime] ,121)+':00:00' as datetime ),    
       right(convert(char(11),[SyncTime] ,14),8)
    FROM
      [Suppliers]
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

Discussions similaires

  1. [Crystal] transformation d'une date en numéro de semaine
    Par barna dans le forum SAP Crystal Reports
    Réponses: 4
    Dernier message: 24/03/2017, 10h41
  2. Récupérer l'année d'une date
    Par delphim dans le forum Langage SQL
    Réponses: 3
    Dernier message: 15/01/2003, 17h33
  3. tester si une date est valide
    Par Andry dans le forum Langage
    Réponses: 5
    Dernier message: 17/09/2002, 12h54
  4. Generation d'evenements a une date precise
    Par pascalzzz dans le forum MFC
    Réponses: 2
    Dernier message: 04/06/2002, 16h21
  5. Réponses: 3
    Dernier message: 19/04/2002, 01h11

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