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 :

Convertir int en heure ?


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2005
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 41
    Par défaut Convertir int en heure ?
    Salut,

    voila j'ai un problème dans ma base de données j'ai un champ heure_resolution qui est en int ex : 683400000000 et moi je souhaiterais avoir un champ qui m'affiche l'heure comme cela : '18:59:00'

    En fait 68340 correspond à 18:59:00 mais en seconde...

    donc comment faire pour convertir mes secondes en heures et minutes ?

    c'est important car je dois effectuer des moyennes et c'est pas pratique avec des int..

    Merci d'avance

  2. #2
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 141
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    DECLARE @Hour AS int,
    		@Minute AS int,
    		@Second AS int
     
    SET @Hour   = 0
    SET @Minute = 0
    SET @Second = 68340
     
    SELECT convert(varchar,dateadd(ss,(@Hour*3600)+(@Minute*60)+@Second,0),108)
    J'espère que cela peut vous aider

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Février 2005
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 41
    Par défaut
    Merci beaucoup,

    mais comment je fais directement avec le champ de ma base de données...

  4. #4
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 141
    Par défaut
    Alors pour ca, je vous conseil de créer une fonction SQL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    create function Time(@Hour int, @Minute int, @Second int)
    returns varchar(8)
    as
        begin			
        return convert(varchar,dateadd(ss,(@Hour*3600)+(@Minute*60)+@Second,0),108)
        end
    go
    Ensuite, vous pouvez utiliser votre fonction de la facon suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select dbo.time(0,0,MaTable.MonChamp) from MaTable
    Je passe 0 pour les 2 premiers paramètres car je ne les utilise pas, mais ils seront peut-être utilisé un jour ou l'autre.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Février 2005
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 41
    Par défaut
    Merci j'ai testé.....

    la fonction marche..

    mais la requête me génère une erreur :

    Arithmetic overflow error converting expression to data type int.

  6. #6
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    141
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

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

    Informations forums :
    Inscription : Juillet 2007
    Messages : 141
    Par défaut
    Etes-vous sûr que votre champ est de type 'int' ?

    Car j'ai effectué le test et cela ne pose pas de problème.

Discussions similaires

  1. convertir int (32bits) en char(8bit)
    Par madjidri dans le forum C++
    Réponses: 2
    Dernier message: 28/05/2007, 18h50
  2. [FAQ] Convertir int to String
    Par mamid1706 dans le forum C++
    Réponses: 2
    Dernier message: 09/05/2007, 15h20
  3. convertir int en Object et int en char
    Par djanos dans le forum Langage
    Réponses: 5
    Dernier message: 24/02/2007, 18h58
  4. Convertir int en chaîne de caractère
    Par be_tnt dans le forum Réseau
    Réponses: 44
    Dernier message: 25/04/2006, 15h35
  5. [Conversion]convertir int[] en bytes[]
    Par tony_big_guy dans le forum Langage
    Réponses: 5
    Dernier message: 02/05/2005, 15h47

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