Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Omvandla en summa av tid via t-sql

Postades av 2003-10-04 02:01:19 - Pelle Johansson, i forum sql-server/msde, Tråden har 4 Kommentarer och lästs av 1079 personer

Hej,

Jag kör sql2000 och har ett fält i en tabell av datatypen (float). Dessa fält summeras via en procedur och man får ett totalvärde som exempelvis är 10.75.

Min fråga är nu om man i T-sql direkt när datat returneras omvandla detta till korrekt antal timma och minuter. 10.75 skall alltså bli 11 tim, 15 minuter.

Tack på förhand


Svara

Sv: Omvandla en summa av tid via t-sql

Postades av 2003-10-04 11:51:08 - Kalle Dahlberg

Hej!

Du får nog använda floor och modulo... Typ:

<code>
declare @sum float
select @sum=10.75

select floor(@sum)+round(100*(@sum-floor(@sum)), 0)/60 as hours,
round(100*(@sum-floor(@sum)))%60 as minutes
</code>

Har ingen server där jag sitter nu så jag kan inte testa, men något liknande borde funka.

EDIT: Skit i denna... Funkar ej :) Håller på och kollar nu


Svara

Sv: Omvandla en summa av tid via t-sql

Postades av 2003-10-04 11:53:55 - Christoffer Hedgate

Eh, menar du inte 10 timmer och 45 minuter? Annars är det ju en mycket konstig lagringsform. 10.75 skulle då vara samma som 11.15 eller?

Om du egentligen menade 10 timmar och 45 minuter så bör detta fungera:

<code>
SELECT FLOOR(kolumn) AS timmar, (kolumn - FLOOR(kolumn)) * 60 AS minuter
FROM tabell
</code>


Svara

Sv: Omvandla en summa av tid via t-sql

Postades av 2003-10-04 12:03:45 - Kalle Dahlberg

Nytt försök (funkar):

<code>
declare @sum float
select @sum=10.75

select floor(@sum)+convert(int, round(100*(@sum-floor(@sum)), 0))/60 as timmar,
convert(int, round(100*(@sum-floor(@sum)), 0)) % 60 as minuter

</code>


Svara

Sv: Omvandla en summa av tid via t-sql

Postades av 2003-10-04 15:02:07 - Pelle Johansson

Fungerade perfekt, tack.

Christoffer - jo det lagras ner konstigt med det är tidrapportering på en massa fält och därmed känns det rätt att hantera detta vid läsning, inte skrivning.

Ex: Kalle arbetar några timmar per dag:

<info>
timeid timesubject timetype period amount
----------- ----------- -------- ------------------------------------------------------ -----------------------------------------------------
10 xx yy 2003-10-02 00:00:00.000 3.2999999999999998
13 xx yy 2003-10-04 00:00:00.000 0.20000000000000001
12 xx yy 2003-10-04 00:00:00.000 1.25
11 xx yy 2003-10-04 00:00:00.000 6.0
</info>

Och summan för detta blir då:

<info>
aar manad totalantal timmar minuter
----------- ----------- ----------- ----------------------------------------------------- -----------
2003 10 4 11.0 15
</info>


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 619
27 953
271 709
587
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies