在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