各种时间类型的转换及比较

来源:互联网 发布:日历行程软件 编辑:程序博客网 时间:2024/06/05 21:07

     我们常用的时间类型不外乎 Date类型,但是想要获取更精准的时间,则需要DateTime或者Timestamp类型。

    下面先简单说一下这三种类型的格式及时间范围:

    1.Date: 年/月/日    时间范围:公元100年1月1日 0:00:00 ~ 9999年12月31日 23:59:59)

     Fri Jul 21 15:33:05 CST 2017(获得date)      2017-33-21 15:07:05  (格式化后)

MySQL用'YYYY-MM-DD'格式检索和显示DATE值

     2.Datetime: MySQL检索并且以'YYYY-MM-DD HH:MM:SS'格式显示DATETIME值,支持的范围是'1000-01-01 00:00:00'到'9999-12-31 23:59:59'。

一些符号标识:

   3.Timestamp:时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数

               默认值:0000-00-00-00.00.00.000000   格式:yyyy-MM-dd HH:mm:ss.fff

 4.TIME数据类型表示一天中的时间。MySQL检索并且以"HH:MM:SS"格式显示TIME值。支持的范围是'00:00:00'到'23:59:59'。

  • y : 年
  • M : 月
  • d:日
  • hH:小时
  • m:分钟
  • s:秒
  • t:12小时制的上下午(AM/PM)
  • z:时区

下面是这几种类型的相互转换:

一、String与Date(java.util.Date)互转

     1.1 String -> Date

  1. String dateStr = "2010/05/04 12:34:23";   
  2.         Date date = new Date();   
  3.         //注意format的格式要与日期String的格式相匹配   
  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
  5.         try {   
  6.             date = sdf.parse(dateStr);   
  7.             System.out.println(date.toString());   
  8.         } catch (Exception e) {   
  9.             e.printStackTrace();   
  10.         }  

  1.2 Date -> String

   日期向字符串转换,可以设置任意的转换格式format

  1. String dateStr = "";   
  2.         Date date = new Date();   
  3.         //format的格式可以任意   
  4.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
  5.         DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH/mm/ss");   
  6.         try {   
  7.             dateStr = sdf.format(date);   
  8.             System.out.println(dateStr);   
  9.             dateStr = sdf2.format(date);   
  10.             System.out.println(dateStr);   
  11.         } catch (Exception e) {   
  12.             e.printStackTrace();   
  13.         }  

 二、String与Timestamp互转

 (Timestamp的值从数据库取出展示在前台有可能是一串数字,此时需要转换为String类型即可以正常显示)

   2.1 String ->Timestamp

   使用Timestamp的valueOf()方法

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   
  2.         String tsStr = "2011-05-09 11:49:45";   
  3.         try {   
  4.             ts = Timestamp.valueOf(tsStr);   
  5.             System.out.println(ts);   
  6.         } catch (Exception e) {   
  7.             e.printStackTrace();   
  8.         }  

   注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!

    如果String为其他格式,可考虑重新解析下字符串,再重组~~

    2.2 Timestamp -> String

  使用Timestamp的toString()方法或者借用DateFormat

 

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   
  2.         String tsStr = "";   
  3.         DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");   
  4.         try {   
  5.             //方法一   
  6.             tsStr = sdf.format(ts);   
  7.             System.out.println(tsStr);   
  8.             //方法二   
  9.             tsStr = ts.toString();  
  10.             System.out.println(tsStr);   
  11.         } catch (Exception e) {   
  12.             e.printStackTrace();   
  13.         }  

 很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。

三、Date( java.util.Date )和Timestamp互转

  声明:查API可知,Date和Timesta是父子类关系

  3.1 Timestamp -> Date

  1. Timestamp ts = new Timestamp(System.currentTimeMillis());   
  2.         Date date = new Date();   
  3.         try {   
  4.             date = ts;   
  5.             System.out.println(date);   
  6.         } catch (Exception e) {   
  7.             e.printStackTrace();   
  8.         }  

 很简单,但是此刻date对象指向的实体却是一个Timestamp,即date拥有Date类的方法,但被覆盖的方法的执行实体在Timestamp中。

   3.2 Date -> Timestamp

   父类不能直接向子类转化,可借助中间的String~~~~

     java.sql.Date 只存储日期数据不存储时间数据
    // 会丢失时间数据
    preparedStatement.setDate(1, new java.sql.Date(date.getTime()));
     //可以这样来处理
      preparedStatement.setTimestamp(1, new java.sql.Timestamp(new java.util.Date().getTime()));

      //想要得到完整的数据,包括日期和时间,可以这样
      java.util.Date d = resultSet.getTimestamp(1);
      //这样处理更合适一些,可以避免一些潜在Timestamp 问题
     java.util.Date d = new java.util.Date(resultSet.getTimestamp(1).getTime());
自己补的话
这样的话:
        往数据库存储的时候可以接收 java.util.Date类型 再用getTime()方法得到代表那个Date对象的long值,再以这个long值 构造一个Timestamp对象 存进数据库中。
       从存数据库里取的时候,可以先得到Timestamp用他的getTime()方法得到long值,再以这个long值构造一个java.util.Date对象,这样就可以对这个Date对象操作了。不如说 new SimpleTimeFormat("yyyyy-MM-dd HH:mm:ss").format()等等

二:时间类型之间的大小比较

1.Date类型compareTo方法

含义:实际上比较的是自1970 年 1 月 1 日 00:00:00 GMT以来的毫秒数。毫秒数越大的时间越大

参数 Date 等于此 Date,则返回值 0;如果此 Date 在 Date 参数之前,则返回小于 0 的值;如果此 Date 在 Date 参数之后,则返回大于 0 的值

2.Timestamp类型getTime()方法

2个timestamp类型的数据不能直接用><=比较大小

可以用下面的方法比较

[html] view plain copy
  1. var timestamp1;  
  2. var timestamp2;  
  3. if( timestamp1.getTime() > timestamp2.getTime())  
这样加上getTime()方法后就可比较了(返回对应的毫秒数(long类型)

注释:      1. java.util.Date类中的getYear()要加上1900才可得到实际值,getMonth()则要加上1。
        2. 字符串到Date的转换: Date.valueOf(str),记得引包的时候要引sql的Date包,不是util的Date包
        3. 字符串到Timestamp 的转换Timestamp ts = Timestamp.valueOf(time);