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

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

公元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值

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

一些符号标识:

时间戳是指格林威治时间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

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

  • y: 年
  • M
  • d:日
  • h或H:小时
  • 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()方法 
Timestamp ts = new Timestamp(System.currentTimeMillis());           String tsStr = "2011-05-09 11:49:45";           try {               ts = Timestamp.valueOf(tsStr);               System.out.println(ts);           } catch (Exception e) {               e.printStackTrace();           }   
 注:String的类型必须形如: yyyy-mm-dd hh:mm:ss[.f...] 这样的格式,中括号表示可选,否则报错!!!    如果String为其他格式,可考虑重新解析下字符串,再重组~~    2.2 Timestamp -> String  使用Timestamp的toString()方法或者借用DateFormat  
Timestamp ts = new Timestamp(System.currentTimeMillis());           String tsStr = "";           DateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");           try {               //方法一               tsStr = sdf.format(ts);               System.out.println(tsStr);               //方法二               tsStr = ts.toString();              System.out.println(tsStr);           } catch (Exception e) {               e.printStackTrace();           }   
 很容易能够看出来,方法一的优势在于可以灵活的设置字符串的形式。三、Date( java.util.Date )和Timestamp互转  声明:查API可知,Date和Timesta是父子类关系  3.1 Timestamp -> Date 
Timestamp ts = new Timestamp(System.currentTimeMillis());           Date date = new Date();           try {               date = ts;               System.out.println(date);           } catch (Exception e) {               e.printStackTrace();           }   
 
  很简单,但是此刻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);