精华内容
下载资源
问答
  • 计算时间差.zip

    2019-06-24 16:02:47
    JavaScript计算时间差代码,可以计算特定时间与现在的时间差,也可以计算今天某一时间与现在的时间差或者现在时间到某一时间的时间差,例子
  • 计算时间差

    2015-12-27 20:39:18
    计算时间差.java
  • CTime计算时间差

    2012-02-14 00:30:28
    C++计算时间差
  • Java计算时间差、日期差总结

    万次阅读 多人点赞 2018-03-13 18:59:00
    Java计算时间差、日期差总结 最近工作中遇到需要计算时间差,搜索了几种计算时间差的方法,这里总结一下 1、java 7中的日历类Calendar Calendar类使用其静态的getInstance()方法获取一个日历实例,该实例为当前...

    Java计算时间差、日期差总结

    最近工作中遇到需要计算时间差,搜索了几种计算时间差的方法,这里总结一下

    1、java 7中的日历类Calendar

    Calendar类使用其静态的getInstance()方法获取一个日历实例,该实例为当前的时间;如果想改变时间,可以通过其setTime方法传入一个Date对象,即可获得Date对象所表示时间的Calendar对象

    /**
     *使用Calendar对象计算时间差,可以按照需求定制自己的计算逻辑
     * @param strDate
     * @throws ParseException
     */
    public static void calculateTimeDifferenceByCalendar(String strDate) throws ParseException {
        SimpleDateFormat formatter = new SimpleDateFormat("yyyy/MM/dd");
        Date date = formatter.parse(strDate);
    
        Calendar c1 = Calendar.getInstance();   //当前日期
        Calendar c2 = Calendar.getInstance();
        c2.setTime(date);   //设置为另一个时间
    
        int year = c1.get(Calendar.YEAR);
        int oldYear = c2.get(Calendar.YEAR);
    
        //这里只是简单的对两个年份数字进行相减,而没有考虑月份的情况
        System.out.println("传入的日期与今年的年份差为:" + (year - oldYear));
    }

    输出为:

    传入的日期与今年的年份差为:12

    2、java 8中的周期类Period

    通过调用Period类的静态方法between,传入两个待比较的LocalDate对象today与oldDate,得到的Period的对象p中就包含了today与oldDate两个日期相差的年、月、日信息,可以通过p.getYears()等方法取出

    /**
     * 使用java 8的Period的对象计算两个LocalDate对象的时间差,严格按照年、月、日计算,如:2018-03-12 与 2014-05-23 相差 3 年 9 个月 17 天
     * @param year
     * @param month
     * @param dayOfMonth
     */
    public static void calculateTimeDifferenceByPeriod(int year, Month month, int dayOfMonth) {
        LocalDate today = LocalDate.now();
        System.out.println("Today:" + today);
        LocalDate oldDate = LocalDate.of(year, month, dayOfMonth);
        System.out.println("OldDate:" + oldDate);
    
        Period p = Period.between(oldDate, today);
        System.out.printf("目标日期距离今天的时间差:%d 年 %d 个月 %d 天\n", p.getYears(), p.getMonths(), p.getDays());
    }

    输出为:

    Today:2018-03-13
    OldDate:2014-05-23
    目标日期距离今天的时间差:3 年 9 个月 18 天

    3、java 8中的Duration类

    Duration与Period相对应,Period用于处理日期,而Duration计算时间差还可以处理具体的时间,也是通过调用其静态的between方法,该方法的签名是between(Temporal startInclusive, Temporal endExclusive),因此可以传入两个Instant的实例(Instant实现了Temporal接口),并可以以毫秒(toMillis)、秒(getSeconds)等多种形式表示得到的时间差

    public static void calculateTimeDifferenceByDuration() {
        Instant inst1 = Instant.now();  //当前的时间
        System.out.println("Inst1:" + inst1);
        Instant inst2 = inst1.plus(Duration.ofSeconds(10));     //当前时间+10秒后的时间
        System.out.println("Inst2:" + inst2);
        Instant inst3 = inst1.plus(Duration.ofDays(125));       //当前时间+125天后的时间
        System.out.println("inst3:" + inst3);
    
        System.out.println("以毫秒计的时间差:" + Duration.between(inst1, inst2).toMillis());
    
        System.out.println("以秒计的时间差:" + Duration.between(inst1, inst3).getSeconds());
    }

    输出为:

    Inst1:2018-03-13T09:06:00.691Z
    Inst2:2018-03-13T09:06:10.691Z
    inst3:2018-07-16T09:06:00.691Z
    以毫秒计的时间差:10000
    以秒计的时间差:10800000

    4、java 8中的ChronoUnit类

    ChronoUnit的between方法签名为,between(Temporal temporal1Inclusive, Temporal temporal2Exclusive),需要注意的是,如果要以不同的单位展示时间差,between入参中的时间对象必须包含有对应的时间信息,否则会抛出java.time.temporal.UnsupportedTemporalTypeException: Unsupported unit XXX的异常

    /**
     * 使用java 8的ChronoUnit,ChronoUnit可以以多种单位(基本涵盖了所有的,看源码发现竟然还有“FOREVER”这种单位。。)表示两个时间的时间差
     */
    public static void calculateTimeDifferenceByChronoUnit() {
        LocalDate startDate = LocalDate.of(2003, Month.MAY, 9);
        System.out.println("开始时间:" + startDate);
    
        LocalDate endDate = LocalDate.of(2015, Month.JANUARY, 26);
        System.out.println("结束时间:" + endDate);
    
        long daysDiff = ChronoUnit.DAYS.between(startDate, endDate);
        System.out.println("两个时间之间的天数差为:" + daysDiff);
    //  long hoursDiff = ChronoUnit.HOURS.between(startDate, endDate);  //这句会抛出异常,因为LocalDate表示的时间中不包含时分秒等信息
    }

    输出为:

    开始时间:2003-05-09
    结束时间:2015-01-26
    两个时间之间的天数差为:4280

    5、传统的SimpleDateFormat类

    用SimpleDateFormat计算时间差的方法,网上找了一份,自己跑了一遍,可以使用,贴在下面

    /**
    * 用SimpleDateFormat计算时间差
    * @throws ParseException 
    */
    public static void calculateTimeDifferenceBySimpleDateFormat() throws ParseException {
        SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm");
        /*天数差*/
        Date fromDate1 = simpleFormat.parse("2018-03-01 12:00");  
        Date toDate1 = simpleFormat.parse("2018-03-12 12:00");  
        long from1 = fromDate1.getTime();  
        long to1 = toDate1.getTime();  
        int days = (int) ((to1 - from1) / (1000 * 60 * 60 * 24));  
        System.out.println("两个时间之间的天数差为:" + days);
    
        /*小时差*/
        Date fromDate2 = simpleFormat.parse("2018-03-01 12:00");  
        Date toDate2 = simpleFormat.parse("2018-03-12 12:00");  
        long from2 = fromDate2.getTime();  
        long to2 = toDate2.getTime();  
        int hours = (int) ((to2 - from2) / (1000 * 60 * 60));
        System.out.println("两个时间之间的小时差为:" + hours);
    
        /*分钟差*/
        Date fromDate3 = simpleFormat.parse("2018-03-01 12:00");  
        Date toDate3 = simpleFormat.parse("2018-03-12 12:00");  
        long from3 = fromDate3.getTime();  
        long to3 = toDate3.getTime();  
        int minutes = (int) ((to3 - from3) / (1000 * 60));  
        System.out.println("两个时间之间的分钟差为:" + minutes);
    }

    输出为:

    两个时间之间的天数差为:11
    两个时间之间的小时差为:264
    两个时间之间的分钟差为:15840

    总结

    传统的SimpleDateFormat和Java 7中的Calendar在使用的时候需要自己写一个计算时间差的逻辑,比较麻烦,但是却比较灵活,方便根据自己具体的需求来定制(比如,我想两个日期的天数差15天就算满一个月,不满15天不算一个月,如2018-01-04到2018-02-20,算2个月的时间差);而Java 8中的几个计算时间差的类更加方便、精确,可以以不同的单位表示得到的时间差,但要注意几个类所包含的时间信息的区别:

    System.out.println(LocalDate.now());        //只包含日期信息
    System.out.println(LocalTime.now());        //只包含时间信息
    System.out.println(LocalDateTime.now());        //包含日期、时间信息

    输出为:

    2018-03-13
    17:13:26.134
    2018-03-13T17:13:26.135

    以上总结的几个方法只是个例子,具体使用的时候可能需要传入一个或者两个时间进行比较,可能会涉及到这些时间对象的相互转换,Instant、Date、LocalDate等等。。。我就不列举了。。。
    另外在使用SimpleDateFormat对String类型的日期进行parse的时候,如果传入的日期为:2017-08-60,这种错误的日期,Java默认会按照日期的信息对其进行转换,formatter.parse("2017-08-60");,得到的日期为2017-09-29,而如果不想进行这种转换,而直接将其判定为输入错误,则可以设置formatter.setLenient(false);,这时就会抛出java.text.ParseException异常了

    SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
    formatter.setLenient(false);
    try {
        Date date = formatter.parse("2017-08-60");  //抛出转换异常
        System.out.println(date);
    } catch (ParseException e) {
        e.printStackTrace();
    }
    展开全文
  • js计算时间差

    2015-05-06 16:43:21
    js计算时间差
  • 在JSP下如何计算时间差
  • 主要介绍了oralce 计算时间差的实现的相关资料,需要的朋友可以参考下
  • java计算时间差的方法

    2020-09-03 12:52:10
    主要介绍了java计算时间差的方法,涉及java针对时间的转换与计算相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
  • 主要介绍了Java中计算时间差的方法,实例分析了java常见的三种计算时间差的技巧,需要的朋友可以参考下
  • 主要介绍了python计算时间差的方法,实例分析了Python时间操作的相关模块与技巧,需要的朋友可以参考下
  • java 计算时间差

    2012-09-04 22:32:38
    多种方法实现时间差计算,在此分享,共大家交流学习
  • 主要介绍了Oracle计算时间差常用函数,涉及用法代码及示例,具有一定参考价值。需要的朋友可以了解下。
  • postgresql 计算时间差

    千次阅读 2019-10-18 11:43:27
    按日期计算天数 # select (('2019-11-18 12:05'::timestamp)::date - ('2019-10-18 12:05'::timestamp)::date) as day; day ----- 31 # select (('2019-11-18 00:05'::timestamp)::date - ('2019-10-18 12:05'...

    按日期计算天数差

    # select (('2019-11-18 12:05'::timestamp)::date - ('2019-10-18 12:05'::timestamp)::date) as day;
     day 
    -----
      31
    
    # select (('2019-11-18 00:05'::timestamp)::date - ('2019-10-18 12:05'::timestamp)::date) as day;
     day 
    -----
      31
    (1 row)
    
    

    按时间计算天数差

    # select date_part('day', '2019-11-18 12:05'::timestamp - '2019-10-18 12:05'::timestamp);
     date_part 
    -----------
            31
    (1 row)
    
    
    # select date_part('day', '2019-11-18 00:05'::timestamp - '2019-10-18 12:05'::timestamp);
     date_part 
    -----------
            30
    (1 row)
    
    

    使用age计算时间差

    # select extract(day from (age('2019-11-18 12:05'::date , '2019-10-18 12:05'::date))) as day;
     day 
    -----
       0
    (1 row)
    
    # select age('2019-11-18 12:05'::date , '2019-10-18 12:05'::date);
      age  
    -------
     1 mon
    (1 row)
    
     #select age('2019-10-18 12:05'::timestamp, '2011-09-16 12:05'::timestamp);
             age          
    ----------------------
     8 years 1 mon 2 days
    (1 row)
    
    

    postgresq age

    https://www.postgresql.org/docs/12/functions-datetime.html

    展开全文
  • Oracle计算时间差

    千次阅读 2018-12-26 08:41:38
    时间差=终止时间-开始时间 1.字符串型(要转化成数字类型) 天:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS'))) 小时:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,...
    时间差=终止时间-开始时间
    
    1.字符串型(要转化成数字类型)
    
    天:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS')))
    
    小时:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS'))*24)
    
    分钟:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS'))*24*60)
    
    秒:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS'))*24*60*60)
    
    毫秒:ROUND(TO_NUMBER(TO_DATE(A.EST_DATE,'YYYYMMDDHH24MISS')-TO_DATE(A.INS_DATE,'YYYYMMDDHH24MISS'))*24*60*60*60)
    
    2.数字型
    
    天:ROUND(TO_NUMBER(END_DATE - START_DATE))
    
    小时:ROUND(TO_NUMBER(END_DATE - START_DATE) * 24)
    分钟:ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60)
    秒:ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60)
    毫秒:ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 60)
    

     

    展开全文
  • sqlserver 计算数据库时间差sqlserver 计算数据库时间差sqlserver 计算数据库时间差sqlserver 计算数据库时间差sqlserver 计算数据库时间差
  • 本篇文章主要介绍了C# TimeSpan 计算时间差(时间间隔),非常具有实用价值,需要的朋友可以参考下。
  • SQL计算时间差

    千次阅读 2020-12-31 09:22:33
    释义:DATEDIFF可以计算开始时间与结束时间的时间差,结果是天数 栗子: 2,TIMESTAMPDIFF函数 语法:TIMESTAMPDIFF(时间粒度,开始时间,结束时间) 释义:(1)时间粒度参数: 2/SECOND--秒:计算开始...

    一、DB2数据库计算时间差

    1,DATEDIFF函数

    语法:DATEDIFF(开始时间,结束时间)

    释义:DATEDIFF可以计算开始时间与结束时间的时间差,结果是天数

    栗子:

     

    2,TIMESTAMPDIFF函数

    语法:TIMESTAMPDIFF(时间粒度,开始时间,结束时间)

    释义:(1)时间粒度参数:

                       2/SECOND--秒:计算开始时间与结束时间相差的秒数。

                       4/MINUTE--分:计算开始时间与结束时间相差多少分钟。

                       8/HOUR--小时:计算开始时间与结束时间相差多少小时。

                       16/DAY--天:计算开始时间与结束时间相差的天数。

                       32/WEEK--周:计算开始时间与结束时间相差的周数。

                       64/MONTH--月:计算开始时间与结束时间相差多少月。

                      128/QUARTER--季:计算开始时间与结束时间相差的季度数。

                       256/YEAR--年:计算开始时间与结束时间相差的年数。

    (2)开始时间:需要计算时间差的开始时间,参数格式需要为时间格式。

    (3)结束时间:需要计算时间差的结束时间,参数格式需要为时间格式。

    栗子:

     

    二、oracle数据库计算时间差

    两个Date类型字段:START_DATE,END_DATE,计算这两个日期的时间差

    语法:ROUND(TO_NUMBER(END_DATE - START_DATE))

    释义:END_DATE为截止日期,START_DATE为开始日期

    例如:

    天:
    ROUND(TO_NUMBER(END_DATE - START_DATE))
    小时:
    ROUND(TO_NUMBER(END_DATE - START_DATE) * 24)
    分钟:
    ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60)
    秒:
    ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60)
    毫秒:
    ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 1000)

    展开全文
  • js计算时间差示例

    千次阅读 2018-11-08 15:10:57
    一、js时间差计算 js中没有更多的时间函数使用,需要自己根据时间差处理 var begin = new Date('2018-10-8 10:00:10'); var end = new Date('2018-10-8 20:05:00'); //时间相差毫秒数 var span = end.getTime...
  • mysql计算时间差函数

    2020-09-10 18:20:17
    MySql计算两个日期的时间差函数TIMESTAMPDIFF用法,只要用一句SQL语句就可以办到了。
  • MySQL计算时间差

    千次阅读 2020-02-28 13:47:41
    Mysql计算时间差公式 假设我们有一张数据表( DateTime),字段id,字段date,数据表中有此内容 计算距离当前时间多少天了 可以使用DATEDIFF:date SELECT DATEDIFF(NOW(),date) FROM DateTime 这样就搞定了 ...
  • 主要介绍了java8 计算时间差的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
  • js计算两个时间的时间差

    热门讨论 2010-12-13 20:43:12
    js计算时间差js计算时间差js计算时间差js计算时间差js计算时间差js计算时间差js计算时间差js计算时间差js计算时间差
  • 下面小编就为大家带来一篇js时间比较 js计算时间差的简单实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
  • 在php中计算时间差有时候是件麻烦的事!不过只要你掌握了日期时间函数的用法那这些也就变的简单了
  • 主要为大家介绍了javascript计算时间差的示例代码,,一般来说都是计算当前时间和一个指定时间点之间的差距,感兴趣的小伙伴们可以参考一下
  • Mysql计算时间差

    千次阅读 2018-06-23 08:55:25
    1、最近在写mysql存储过程时,用到计算时间差的东西,特此记录一下。 2、SELECT TIMESTAMPDIFF(MONTH,'2009-10-01','2009-09-01');  3、其中 TIMESTAMPDIFF 是Mysql中计算时间差的函数名,MONTH 为计算出的事件...
  • 主要介绍了Shell时间运算及时间差计算方法,本文讲解了时间时间加减运算以及时间差计算方法,需要的朋友可以参考下

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 463,969
精华内容 185,587
关键字:

怎样计算时间差