当前位置: 代码迷 >> Sql Server >> sqlserver计算两个日期之差,精确到毫秒,该如何解决
  详细解决方案

sqlserver计算两个日期之差,精确到毫秒,该如何解决

热度:75   发布时间:2016-04-24 09:16:48.0
sqlserver计算两个日期之差,精确到毫秒
declare @starttime datetime,@endtime datetime
set @starttime='2012-10-07 10:57:23.957'
set @endtime  ='2012-11-08 08:31:03.224'

如题,我要计算@endtime与@starttime的差值;应该得到 几天 几小时 几分 几秒 几毫秒

select datediff(part,@starttime,@endtime)
part使用day计算出来是32天,不对;
part使用ss,ss最大是60几天,超出的话不对;
part使用ms,ms最大是24小时多少多少,超出不对。

大神们,你们是怎么做的啊? 
------解决思路----------------------
加了个case when 判断
declare @starttime datetime2,@endtime datetime2
set @starttime='2012-10-07 10:57:23.957'
set @endtime  ='2012-11-08 08:31:03.224'

SELECT  CASE WHEN DATEDIFF(hour, @starttime, @endtime) < 24
             THEN CONVERT(VARCHAR(10), DATEDIFF(DAY, @starttime, @endtime) - 1)
             ELSE CONVERT(VARCHAR(10), DATEDIFF(DAY, @starttime, @endtime))
        END + '天' + CONVERT(VARCHAR(10), DATEDIFF(hour, @starttime, @endtime)
        % 24) + '时' + CONVERT(VARCHAR(10), DATEDIFF(mm, @starttime, @endtime)
        % 60) + '分' + CONVERT(VARCHAR(10), DATEDIFF(ss, @starttime, @endtime)
        % 60) + '秒'


/*
------------------------------------------------
32天22时1分40秒

(1 行受影响)
*/

------解决思路----------------------
declare @starttime datetime,@endtime datetime,@T datetime
set @starttime='2012-10-07 10:57:23.957'
set @endtime  ='2012-11-08 08:31:03.224'
select @T = cast( cast(@endtime as float)-cast(@starttime as float) as datetime)
select cast(datediff(day,'1900-01-01',@T)as varchar(10))+'天'+cast(datepart(hh,@T)as varchar(10))
+'小时'+cast(datepart(mi,@T)as varchar(10))+'分'+cast(datepart(ss,@T)as varchar(10))+'秒'
+cast(datepart(ms,@T)as varchar(10))+'毫秒'

/*----------------------------------------------------------------
31天21小时33分39秒267毫秒

(1 行受影响)
*/

------解决思路----------------------
日期本来就可以转换为数值型。
DECLARE @a DATETIME 
SET @a=0
SELECT @a

0代表1900-01-01 00:00:00.000 

那些值是从0开始加上去,好像是秒数
  相关解决方案