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 :

Additionner des temps


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut Additionner des temps
    Bonjour

    J'ai une liste de durées sous forme de texte qui peuvent petre des secondes ou des minutes:secondes ou enfin des heures:minutes:secondes.
    Il faudrait que je fasse l'addition pour avoir un temps total.

    '02:52'
    '03:45'
    '01:42:30'

    Total en heures:minute:secondes ??

    J'ai essayé une conversion en time mais l'addition est impossible.
    Avec des timestamp, ça fait une concaténation simple.

    Je peux le faire par un découpage et des opérations successives mais peut-être qu'il existe une solution plus directe ??

  2. #2
    Expert confirmé

    Avatar de François DORIN
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2016
    Messages
    2 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2016
    Messages : 2 761
    Billets dans le blog
    21
    Par défaut
    Bonjour,

    Il faut faire un peu de gymnastique avec les DATETIME.

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    WITH Data (s)
    AS (
    SELECT '02:52'
    UNION 
    SELECT '03:45'
    UNION
    SELECT '01:42:30'
    )
    SELECT DATEADD(s, SUM(DATEDIFF(s, '1900-01-01', CONVERT(DATETIME2, s))), '1900-01-01')  FROM Data

    Le principe :
    • la date par défaut est le 01/01/1900 sous SQL Server. Et donc quand on convertie une heure en datetime, la partie date prend cette valeur ;
    • pour connaître le nombre de secondes correspondant, on utilise donc DATEDIFF, en prenant le 01/01/1900 comme date de référence ;
    • on somme les secondes ;
    • on convertie les secondes en heure, en utilisant DATEADD pour ajouter les secondes à la date de référence ;
    • enjoy


    Il ne reste qu'à afficher le DATETIME obtenu avec le format désiré...

  3. #3
    Membre confirmé
    Homme Profil pro
    Analyste d'exploitation
    Inscrit en
    Octobre 2016
    Messages
    144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Analyste d'exploitation
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2016
    Messages : 144
    Par défaut
    bonjour François DORIN et merci pour vos requéte

    mais je pense que le '02:52' selon la question de Papy214 représente le format minute:seconde

    02:52 c'est 00:02:52

  4. #4
    Expert confirmé

    Avatar de François DORIN
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2016
    Messages
    2 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2016
    Messages : 2 761
    Billets dans le blog
    21
    Par défaut
    Effectivement, judicieuse remarque !
    Une première passe pour harmoniser les entrées est donc nécessaire (concaténer '00:' si les heures ne sont pas précisées). Cela peut se faire facilement en se basant sur la taille, en nombre de caractères, de l'entrée.

  5. #5
    Membre Expert

    Homme Profil pro
    Retraité
    Inscrit en
    Novembre 2007
    Messages
    3 530
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut
    ah ouais, quand même

    J'ai du mal à comprendre la syntaxe de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DATEDIFF(s, '1900-01-01', CONVERT(DATETIME2, s))
    Dans l'exemple, s est une représentation d'heure (voire de date) alors que l'aide de la fonction semble attendre en premier paramètre yy, qqq, dd, day, year etc.

    mais effectivement ça fonctionne si je complète les minutes avec les heures si elles ne sont pas présentes

    Merci

  6. #6
    Expert confirmé

    Avatar de François DORIN
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2016
    Messages
    2 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2016
    Messages : 2 761
    Billets dans le blog
    21
    Par défaut
    Citation Envoyé par Papy214 Voir le message
    Dans l'exemple, s est une représentation d'heure (voire de date) alors que l'aide de la fonction semble attendre en premier paramètre yy, qqq, dd, day, year etc.
    Un petit tour sur la documentation de cette fonction te permettra de savoir d'où vient ce s

Discussions similaires

  1. Comment additionner des lignes de temps (durée)
    Par xyloup dans le forum Access
    Réponses: 3
    Dernier message: 25/11/2016, 15h04
  2. Additionner des secondes à un temps
    Par LePapat26 dans le forum MATLAB
    Réponses: 3
    Dernier message: 12/01/2009, 23h16
  3. Réponses: 4
    Dernier message: 14/10/2005, 14h02
  4. [Oracle 8i]Sommer des temps
    Par venusiafalls dans le forum Oracle
    Réponses: 15
    Dernier message: 19/07/2005, 10h09
  5. [CR] Additionner des heures
    Par sbis dans le forum Formules
    Réponses: 4
    Dernier message: 22/03/2004, 15h34

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