-
20-09-2019 - |
题
我怎样才能得到整个时间这样datediff(time, logindate, logoutdate)
我知道这个内置的功能不接受时的说法,但我怎么能得到的全部时间,而不是分钟,毫秒,秒等?
logindate datetime2
logoutdate datetime2
我想是这样1点05分45秒,而不是它的一部分。
解决方案
<强>尝试这强>
create table dbo.UserLog (UserID VARCHAR(32),loginDate DATETIME,logoutDate DATETIME)
insert into userLog VALUES ('SPARKY','11/14/2009 3:25pm',getDate())
insert into userLog VALUES ('JANNA','11/14/2009 10:45am',getDate())
select UserId,loginDate,logoutDate,
convert(varchar(12),dateAdd(mi,datediff(mi,logindate,logoutdate),'Jan 1 1753 12:00AM'),114) as timeSpent
FROM userLog
<强>基本上,将所述日期之间的差分钟到最早的有效SQL日期和返回格式化为一个时间的值。强>
其他提示
要具有在天差:
select cast(logoutdate - logindate as float) from table_name
或只是
select logoutdate - logindatefrom table_name
可以从它评估日,小时,分钟。
修改强>
要它已格式化为时间:
SELECT CONVERT(VARCHAR,DATA_KOSZTU - DATA_OST_ZMIANY,108) FROM TR_KOSZT
,它会工作,如果没有登录为24小时以上的用户因为CONVERT用于格式化日期时间,而不是时间跨度。
由于MSSQL没有timepsan数据类型,datediff
在从毫秒绝对整数返回年应该够你创建的.NET说TimeSpan
一个实例。
什么SQL Server版本你在说什么?在SQL Server 2000和以后,至少
SELECT datediff(ss,'2006-11-10 05:47:53.497','2006-11-10 05:48:10.420')
会给你这两个日期时间之间的差(秒)。
E.g。 选择转换(VARCHAR(10),GETDATE(),108)
下面就是你正在寻找的解决方案。
DECLARE @Date1 datetime
DECLARE @Date2 datetime
SET @Date2 = '2006-11-15 07:26:25.000'
SET @Date1 = '2009-11-15 05:35:45.000'
-- -----------------------
-- Math done by hand 1:50:40
--
DECLARE @TotalSeconds bigint
DECLARE @Hours bigint
DECLARE @Minutes bigint
DECLARE @Seconds bigint
DECLARE @HH varchar(20)
DECLARE @MM varchar(2)
DECLARE @SS varchar(2)
DECLARE @Result varchar(50)
--
SET @TotalSeconds = datediff(ss,@Date1 ,@Date2)
SET @Hours = FLOOR(@TotalSeconds / 3600)
SET @TotalSeconds = @TotalSeconds % 3600
SET @Minutes = FLOOR(@TotalSeconds / 60)
SET @Seconds = @TotalSeconds % 60
--
SET @HH = CAST(@Hours as varchar)
SET @MM = CAST(@Minutes as varchar)
SET @SS = CAST(@Seconds as varchar)
IF @Minutes < 10 SET @MM = '0' + @MM
IF @Seconds < 10 SET @SS = '0' + @SS
--
SET @Result = @HH + ':' + @MM + ':' + @SS
SELECT @Result
不隶属于 StackOverflow