SQL中得到两个日期之间相隔 xx天xx小时xx分xx秒

 

该方法简单有效,原创。

 

 select    cast( datediff( ss, '2021-5-30 11:00', GETDATE() ) / 86400 as varchar)  +'天'+
                cast( datediff( ss, '2021-5-30 11:00', GETDATE() ) % 86400 / 3600 as varchar)  +'小时'+
                cast( datediff( ss, '2021-5-30 11:00', GETDATE() ) % 3600 / 60 as varchar)  +'分'+
                cast( datediff( ss, '2021-5-30 11:00', GETDATE() ) % 60 as varchar) + '秒'

 

==========以下是转载===========

SQL SERVER中可以这么做:

 

DECLARE @dt1 AS datetime, @dt2 AS datetime;

SELECT @dt1 = '2008-8-4 9:36:41', @dt2 = '2008-8-2 9:33:39';

DECLARE @Days AS int, @Hours AS int, @Minutes AS int, @Seconds AS int;

SET @Seconds = DATEDIFF( ss, @dt2, @dt1);

SET @Days = @Seconds / (24 * 60 * 60)

SET @Seconds = @Seconds - @Days * 24 * 60 * 60

SET @Hours = @Seconds / (60 * 60);

SET @Seconds = @Seconds - @Hours * 60 * 60

SET @Minutes = @Seconds / 60;

SET @Seconds = @Seconds - @Minutes * 60;

SELECT CONVERT(varchar(10), @Days ) + '天'
          + CONVERT(varchar(10), @Hours ) + '小时'
          + CONVERT(varchar(10), @Minutes ) + '分'
          + CONVERT(varchar(10), @Seconds ) + '秒';

1 按照某种格式输出系统时间:自学java的时间。自学Date类(java.util.Date)和SimpleDateFormat类,用程序输出“当前时间是XXXXXXXXXXXXXX(第XX周,周X)” 2 比较String与StringBuffer、StringBuilder的自增速度。方法:在自增前记录系统时间,进行5000次自增,然后再记录系统时间,可以得出自增的速度。获取系统时间的方法是java.lang.System.currentTimeMillis() ,见JDK API。 3 定义点类,圆是由圆心(点)和半径组成的,请完成圆类,注意“派”为常量,取3.14。圆类具有judge函数可以判断两圆的关系:相离、相交(包括相切)、嵌套、重合。设计static成员用以求所有圆对象的平均面积。(static、final) 4 图形间的关系可以下图用来表现。所有的图形都可以称为Shape。由这个类可以派生出二维图形TwoDimensionalShape和三维图形ThreeDimensionalShape类。每个TwoDimensionalShape类应包括成员函数getArea以计算二维图形的面积。每个ThreeDimensionalShape类包含成员函数getArea和getVolume,别计算三维图形的表面积和体积。编写一个程序,用一个数组乘放各种图形类对象(包括二维和三维的),并输出对象得相应信息。如果某个图形是TwoDimensionalShape就显示其面积,如果某个图形是ThreeDimenionalShape,则显示其面积和体积。请完成图所有的类并在主函数做测试。(继承与多态)
SQL,我们可以使用DATEDIFF函数计算任意两个日期之间的差值,其返回值为两个日期之间的时间差,单位为小时钟或。 但是,这个函数只能计算数或数,不能直接计算小时钟。所以,我们需要进行一些简单的计算,将数转换为小时,再将小时转换为钟和。 对于求时间差的问题,我们可以使用以下简单的步骤: 1.计算两个日期之间数 我们可以使用DATEDIFF函数来计算两个日期之间数。例如,我们可以使用以下查询语句来计算两个日期之间数: SELECT DATEDIFF(day, '2020-01-01', '2020-01-10'); 这将返回一个整数,即日期2020年1月10日和2020年1月1日之间数。 2.将数转换为小时数 将数乘以24,并将其结果添加到查询,以计算小时数。例如,我们可以使用以下查询语句来计算两个日期之间小时数: SELECT DATEDIFF(hour, '2020-01-01', '2020-01-10') + DATEDIFF(day, '2020-01-01', '2020-01-10') * 24; 在这个例子,我们首先计算了数,并将其乘以24,以得到小时数。然后我们使用DATEDIFF函数计算两个日期之间小时数,并将其与数乘以24的结果相加,以得到最终的小时数。 3.将小时数转换为钟和 对于计算钟和的问题,我们可以通过使用DATEDIFF函数将小时数转换为钟和。例如,我们可以使用以下查询语句来计算两个日期之间钟数: SELECT DATEDIFF(minute, '2020-01-01', '2020-01-10') + DATEDIFF(hour, '2020-01-01', '2020-01-10') * 60; 在这个例子,我们首先使用DATEDIFF函数计算了两个日期之间小时数。然后,我们将其乘以60,以得到总的钟数。最后,我们将钟数与小时数相加,得到最终的钟数。 对于计算数的问题,我们可以使用相同的方法,只需要将钟数乘以60即可。 综上所述,我们可以使用DATEDIFF函数以及一些简单的计算,来计算任意两个日期之间的时间差,从而得到我们需要的答案。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值