在Web开发中,避免不了对日期的操做,经常使用的关于时间的类有这么几个:
java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp,这几个类在JDK的定义以下所示:
java.lang.Object
java.util.Date
java.sql.Date/java.sql.Timestamp/java.sql.Time
java.security.Timestamp
java.util.Date日期格式为:年月日时分秒
java.sql.Date日期格式为:年月日[只存储日期数据不存储时间数据,是专门针对sql设计]
java.sql.Time日期格式为:时分秒
java.sql.Timestamp日期格式为:年月日时分秒纳秒(毫微秒)
这些类的关系以下所示:
java.util.Date这个类是java.sql.Date, java.sql.Time, java.slq.Timestamp这三个类的父类。这三个类对java.util.Date类进行了包装。java
java.sql.Date类屏蔽了java.util.Date类的时间有关的方法(形如:hh:mm:ss),所以,不能够经过这个类访问时间有关的信息,好比,若是你经过sqlDate.getHour()方法去访问小时信息,此方法会抛出一个IllegalArgumentException异常。这是由于java.sql.Date在继承java.util.Date类的时候对父类进行了重写,禁用了时间访问的方法。之因此这么处理,是为了和数据库的Date数据类型相匹配,数据库的Date数据类只是保存日期有关的字段。可是它java.sql.Date类有getTime方法返回毫秒数,因此它能够与java.util.Date进行互换:
java.sql.Date转为java.util.Date
java.sql.Date sqlDate=new java.sql.Date();
java.util.Date utilDate=new java.util.Date (sqlDate.getTime());
java.util.Date转为java.sql.Date
java.util.Date utilDate=new Date();
java.sql.Date sqlDate=new java.sql.Date(utilDate.getTime());sql
java.sql.Time类屏蔽了java.util.Date的日期有关的字段(形如:yyyy-MM-dd),所以,不能经过这个类访问日期有关的信息,好比:若是你经过sqlTime.getYear()方法去获取年有关的信息,此方法会抛出一个IllegalArgumentException异常。这是由于java.sql.Time在继承java.util.Date类的时候对父类进行了重写,禁用了日期访问的方法。之因此这么处理,是为了和数据库的Time数据类型相匹配,数据库的Time数据类行只是保存时间有关的字段。数据库
java.sql.date 是只包含了日期。而 java.sql.time 只包含了一个时间。java.sql.time java.sql.date 两者如何组合成一个java.util.date呢?取毫秒相加,做为java.util.date的构造方法参数就能够了。
java.sql.Date d = new java.sql.Date(new java.util.Date().getTime());
java.sql.Time t = new java.sql.Time(new java.util.Date().getTime());
java.util.Date day = new java.util.Date(d.getTime() + t.getTime());
java.sql.Timestamp字段则对java.util.Date这个类进行了扩充,它在java.util.Date类的基础上增长了毫秒的时间访问控制,所以,你能够经过getNanos方法去获取时间的毫微秒数(注意此处获取的时间是以毫微秒为单位的,1秒等于十亿毫微秒),一样的,这也是为了和数据库中的Timestamp数据类型进行匹配。spa
理清了上述四个类的关系,那么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,并把它返回给用户使用。设计
附上例子:code
java.util.Date是在除了SQL语句的状况下面使用的。
java.sql.Date是针对SQL语句使用的,它只包含日期而没有时间部分
它们都有getTime方法返回毫秒数,天然就能够直接构建。 java.util.Date 是 java.sql.Date 的父类,前者是经常使用的表示时间的类,咱们一般格式化或者获得当前时间都是用他,后者以后在读写数据库的时候用他,由于PreparedStament的setDate()的第2参数和ResultSet的getDate()方法的第2个参数都是java.sql.Date。orm
java.sql.Date转为java.util.Date
继承
java.sql.Date date=new java.sql.Date(); java.util.Date d=new java.util.Date (date.getTime());
java.util.Date转为java.sql.Date
ci
java.util.Date utilDate=new Date(); java.sql.Date sqlDate=new java.sql.Date(utilDate.getTime()); java.util.Date utilDate=new Date(); java.sql.Date sqlDate=new java.sql.Date(utilDate.getTime()); java.sql.Time sTime=new java.sql.Time(utilDate.getTime()); java.sql.Timestamp stp=new java.sql.Timestamp(utilDate.getTime());
这里全部时间日期均可以被SimpleDateFormat格式化format()
开发
SimpleDateFormat f=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); f.format(stp); f.format(sTime); f.format(sqlDate); f.format(utilDate) java.sql.Date sqlDate=java.sql.Date.valueOf(" 2005-12-12"); utilDate=new java.util.Date(sqlDate.getTime());
另类取得年月日的方法:
import java.text.SimpleDateFormat; import java.util.*; java.util.Date date = new java.util.Date(); //若是但愿获得YYYYMMDD的格式SimpleDateFormat sy1=new SimpleDateFormat("yyyyMMDD"); String dateFormat=sy1.format(date); //若是但愿分开获得年,月,日SimpleDateFormat sy=new SimpleDateFormat("yyyy"); SimpleDateFormat sm=new SimpleDateFormat("MM"); SimpleDateFormat sd=new SimpleDateFormat("dd"); String syear=sy.format(date); String smon=sm.format(date); String sday=sd.format(date)