java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和总结

在web开发中,避免不了对日期的操做,就几种常见的日期操做作个总结(部分参考网络,在此表示感谢):html

java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp
java

 

java.lang.Object 
....|__java.util.Date 
..........|__java.sql.Date/java.sql.Timestamp /java.sql.Timeweb

....|__java.security.Timestampsql

 

java.util.Date日期格式为:年月日时分秒 
java.sql.Date日期格式为:年月日[只存储日期数据不存储时间数据] 
java.sql.Time日期格式为:时分秒 
java.sql.Timestamp日期格式为:年月日时分秒纳秒(毫微秒)数据库

关系:api

    java.util.Date这个类是java.sql.Date,  java.sql.Time,  java.slq.Timestamp这三个类的父类。这三个类对java.util.Date类进行了包装。网络

联系:spa

    java.sql.Date类屏蔽了java.util.Date类的时间有关的方法(形如:hh:mm:ss),所以,不能够经过这个类访问时间有关的信息,好比,若是你经过sqlDate.getHour()方法去访问小时信息,此方法会抛出一个IllegalArgumentException异常。这是由于java.sql.Date在继承java.util.Date类的时候对父类进行了重写,禁用了时间访问的方法。之因此这么处理,是为了和数据库的Date数据类型相匹配,数据库的Date数据类行只是保存日期有关的字段。code

    Java.sql.Time类屏蔽了java.util.Date的日期有关的字段(形如:yyyy-MM-dd),所以,不能经过这个类访问日期有关的信息,好比:若是你经过sqlTime.getYear()方法去获取年有关的信息,此方法会抛出一个IllegalArgumentException异常。这是由于java.sql.Time在继承java.util.Date类的时候对父类进行了重写,禁用了日期访问的方法。之因此这么处理,是为了和数据库的Time数据类型相匹配,数据库的Time数据类行只是保存时间有关的字段。server

  Java.sql.Timestamp字段则对java.util.Date这个类进行了扩充,它在java.util.Date类的基础上增长了毫秒的时间访问控制,所以,你能够经过getNanos()方法去获取时间的毫微秒数(注意此处获取的时间是以毫微秒为单位的,1秒等于十亿毫微秒),一样的,这也是为了和数据库中的Timestamp数据类型进行匹配。

理清了上述四个类的关系,那么java.util.Date和java.util.Calendar类有什么关系呢?

   Java.util.Calendar类是java.util.Date类的一个更加深刻,更加全面的替代。Java.util.Calendar类支持java.util.Date的全部功能,此外,Calendar还引入了多语言,多区域的特性,能够根据须要获取不一样区域,不一样时区的时间,Calendar还增长了比Date更加方便和快捷的许多操做,如获取一年当中的第几个星期,各个月的天数等便捷的方法。

 

注意:

Java.util.Calendar区别与java.util.Date的几个地方也须要注意一下:首先,Calendar增长了毫秒的时间段,经过它能够获取时间点的毫秒值,而java.util.Date只是精确到秒。其次,Calendar过去年的时候是当前年份好比:2010,而Date获取年份的时获取到的是当前年份-1900的一个值(2010-1900=110,所以,你调用getYear后过去的值就是110)。最后Calendar是一个抽象类,之因此可以实例化,是由于此处的Calendar充当了一个相似于工厂的做用,在getInstance方法中实例化了Calendar子类GregorianCalendar,并把它返回给用户使用。

 

针对不一样的数据库选用不一样的日期类型 
·例如:Oracle的Date类型,只须要年月日,选择使用java.sql.Date类型 
·MS Sqlserver数据库的DateTime类型,须要年月日时分秒,选择java.sql.Timestamp类型

转载:http://www.iteye.com/topic/1137830

相关文章
相关标签/搜索