日期:2014-05-17  浏览次数:20639 次

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小时多少多少,超出不对。

大神们,你们是怎么做的啊? 
------最佳解决方案--------------------
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 行受影响)
*/

------其他解决方案--------------------
加了个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 @a DATETIME 
SET @a=0
SELECT @a

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

那些值是从0开始加上去,好像是秒数
------其他解决方案--------------------
declare @starttime datetime,@endtime datetime
set @starttime='2012-10-07 10:57:23.957'
set @endtime  ='2012-11-08 08:31:03.224'

SELECT CONVERT(VARCHAR(10),DATEDIFF(DAY,@starttime,@endtime))+'天'+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 行受影响)
*/

------其他解决方案--------------------
写程序去处理时间吧,不要在数据库里纠结了。
------其他解决方案--------------------