sql 中,如何获取两个日期之前月数、周数、天数

1、获取两个日期之间的月数、周数、天数语法

   --1、获取两个日期之间的月数、周数、天数
    --1.1)声明参数
    declare @startDate varchar(20)
    declare @endDate varchar(20)
    --1.2)获取两个日期直接的月数
    select DATEDIFF(MM,@startDate,@endDate)
     --1.3)获取两个日期直接的月数
    select DATEDIFF(WW,@startDate,@endDate)
     --1.4)获取两个日期直接的月数
    select DATEDIFF(DD,@startDate,@endDate)

2、测试用例

    --2、测试用例
    --2.1)获取指定日期和当前日期直接的月数
    select DATEDIFF(MM,'2017-08-12 11:12:23',GETDATE()) as 月数
    --2.2)获取指定日期和当前日期直接的周数
    select DATEDIFF(WW,'2017-08-12 11:12:23',GETDATE()) as 周数
    --2.3)获取指定日期和当前日期直接的月数
    select DATEDIFF(DD,'2017-08-12 11:12:23',GETDATE()) as 天数

3、测试结果

想要利用Java的Calendar计算两个日期之间的天数周数,首先需要获取两个日期的Calendar对象。 获取Calendar对象的方法有多种,可以使用Calendar类提供的getInstance()方法或new GregorianCalendar()方法来创建对象。接着,通过set()方法分别设置两个日期的年、、日信息,最后调用getTimeInMillis()方法获取时间戳(单位为毫秒)。 由于时间戳是以毫秒为单位的,因此计算两个日期之间的毫秒数可以通过相减获取。然后将得到的毫秒数转换成天数周数即可。 具体实现代码如下: ```java Calendar cal1 = new GregorianCalendar(); cal1.set(year1, month1 - 1, day1); // 第一个日期的年、、日信息 long time1 = cal1.getTimeInMillis(); // 转换成毫秒数 Calendar cal2 = new GregorianCalendar(); cal2.set(year2, month2 - 1, day2); // 第二个日期的年、、日信息 long time2 = cal2.getTimeInMillis(); // 转换成毫秒数 // 计算两个日期之间的毫秒数 long betweenDays = (time2 - time1); // 转换成天数并输出 int days = (int) (betweenDays / (1000 * 60 * 60 * 24)); System.out.println("两个日期之间相差" + days + "天"); // 转换成周数并输出 int weeks = (int) (betweenDays / (1000 * 60 * 60 * 24 * 7)); System.out.println("两个日期之间相差" + weeks + "周"); ``` 在计算日期之间的天数周数时,需要注意的是,使用Calendar时,份从0开始计数,因此需要将份减1。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值