我希望能够计算出两个日期时间变量之间的确切小时差。这个小时差应该像这样是精确的:
1.5
2
6.25
有人能帮个忙吗?先谢谢了...
我希望能够计算出两个日期时间变量之间的确切小时差。这个小时差应该像这样是精确的:
1.5
2
6.25
有人能帮个忙吗?先谢谢了...
DATEDIFF
函数找到分钟差并将其转换为小时:select datediff(mi, startdate, enddate)
假设1.5代表1小时30分钟,您可以将结果除以60:
select datediff(mi, startdate, enddate) / 60.0
保持简单:
declare @date1 datetime
declare @date2 datetime
select @date1 = GETDATE();
select @date2 = '2013-02-02 14:05'
select DATEDIFF(hh, @date2, @date1)
Results
-----------
71
(1 row(s) affected)
DATEDIFF
返回一个整数,因此它不会给出小数部分,例如分钟。 - Tobseyit will help you....
Declare @Date1 dateTime
Declare @Date2 dateTime
Set @Date1 = '22:30:00'
Set @Date2 = '00:00:00'
Select Cast((@Date1 - @Date2) as Float) * 24.0
FLOAT
之外。 - Pred
Declare @InTime datetime='2017-11-27 10:00:00',
@OutTime datetime='2017-11-27 11:15:00'
SELECT CONVERT(varchar(5),DATEADD(minute,DATEDIFF(minute,@InTime,@OutTime),0), 114)
-----------
Result
01:15
Please try:
declare @dt1 datetime, @dt2 datetime, @Seconds int
select @dt1='2013-02-05 14:05:55.113', @dt2 =getdate()
set @Seconds=datediff(second, @dt1, @dt2)
declare @Hour nvarchar(50)
declare @Min nvarchar(50)
declare @MinTemp int
if @Seconds >0
begin
set @Hour=cast((@Seconds / 3600) as nvarchar(20)) +' Hrs '
set @MinTemp= (@Seconds % 3600) / 60
set @Min=cast(@MinTemp as nvarchar(20))
if @MinTemp<10
select @Hour+'0'+@Min +' Min'
else
select @Hour+@Min +' Min'
end
else
select '00 Hrs 00 Min'