java的时间问题

1.计算2个日期之间的天数

在测试工作中经常会使用到比较两个日期相差的天数,我之前用过实现这一功能的两个版本的方法,源代码如下:

(版本1

publicstaticint getIntervalDays(Date fDate, Date oDate) {

       if (null == fDate || null == oDate) {

           return -1;

       }

       long intervalMilli = oDate.getTime() - fDate.getTime();

       return (int) (intervalMilli / (24 * 60 * 60 * 1000));

    }

 

    (版本2

publicstaticint daysOfTwo(Date fDate, Date oDate) {

       Calendar aCalendar = Calendar.getInstance();

       aCalendar.setTime(fDate);

       int day1 = aCalendar.get(Calendar.DAY_OF_YEAR);

       aCalendar.setTime(oDate);

       int day2 = aCalendar.get(Calendar.DAY_OF_YEAR);

       return day2 - day1;

    }

   

为什么使用这两个版本的方法,因为我使用过程中,遇到了和我预期不一致的情况,比如下面一个使用范例

 

    publicstaticvoid main(String[] args) {

       Date fDate = new GregorianCalendar().getTime();

       Date oDate = new GregorianCalendar(2009, 2, 15,13,13,0).getTime();

       System.out.println("使用 getIntervalDays 相差天数 = "

                     getIntervalDays(fDate, oDate));

      

       System.out.println("使用 daysOfTwo 相差天数 = "

              daysOfTwo(fDate, oDate));

}

这个例子中调用了两个版本的方法,但输出结果有时不相同,此前我一直不明白为什么,后来细心研究了一下,原来是我对这两个版本的方法没有清楚的理解。版本1的方法要比较的严格意义上的天,举个例子,计算今天与昨天比较相差几天,我们或许都认为是1,但我们要输入两个日期类型的参数,这个日期中不仅包含天,还有小时,分等,版本1会根据您输入的小时与分不同,返回不同的结果的,比如你输入的参数今天中午与昨天晚上的两个时间,它就会告诉你相差0天。同样的输入版本2只关心天,输出的结果是1,也是我想要的结果。总结起来这两个方法都是对的,关键的是调用者要明白你想要的究竟是什么样的结果。

2.从Mysql数据库中查询前一天的数据
select * from Table where datediff(now(),'你表里的日期字段',"D")=1

猜你喜欢

转载自blog.csdn.net/qq_39141360/article/details/79397579