Hej, Hej! 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? Nytt försök (funkar): Fungerade perfekt, tack.Omvandla en summa av tid via t-sql
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örhandSv: Omvandla en summa av tid via t-sql
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 nuSv: Omvandla en summa av tid via t-sql
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>Sv: Omvandla en summa av tid via t-sql
<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>Sv: Omvandla en summa av tid via t-sql
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>