本文总结了java.util.Date和java.sql.Date的不同。非原创,是基于stack overflow的问答的总结。
原贴:
http://stackoverflow.com/questions/2305973/java-util-date-vs-java-sql-date
类图如下图如示,java.sql.Date 是java.util.Date的子类。
一般来说,数据库通常支持三种以上的时间格式,即:DATE, TIME,以及TIMESTAMP。每种都对应着一个JDBC类,即:java.sql.Date,java.sql.Time,java.sql.Timestamp。而以上三个类都继承了java.util.Date类。
1、 java.sql.Date对应着SQL的DATE(即:'YYYY-MM-DD'),表示年月日。(没错,是没有时分秒的)。此外,sql.Date没有时区。
2、 java.sql.Time对应着SQL的TIME,它只包含了时分秒(即:'HH:MM:SS'),以及毫秒信息。
3、 java.sql.Timestamp对应着SQL的TIMESTAMP(时间戳),支持纳秒。(值得注意的是:util.Date只支持毫秒。)
java.sql.Date | DATE | YYYY-MM-DD |
java.sql.Time | TIME | HH:MM:SS |
java.sql.Timestamp | TIMESTAMP | |
最常见的一个bug是用在用与数据库相关的这三种类型(即java.sql.*)时,没有正确的使用,比如sql.Date是无时区的,sql.Time没有年月日的。
最后:要怎样选择?
这个取决于数据库的列类型。 PreparedStatement有所有类型的setter方法。即:
PreparedStatement#setDate() | sql.Date |
PreparedStatement#setTime() | sql.Time |
PreparedStatement#setTimestamp() | sql.Timestamp |
注意:如果是使用ps.setObject(fieldIndex, utilDateObject); 第二个参数可以传入util.Date类型,因为大多数的JDBC驱动可以识别并转成相对应正确的类型。再次取出的时候,需要注意的是可能会丢失掉一些信息(比如DATE类型,拿出的时候会丢掉时分秒信息)。
建议:不要使用以上任何一种Date类型。
比较推荐的做法是存放时间格式的时候用毫秒或纳秒格式存放(long数据类型),然后在取出的时候使用joda-time(http://www.joda.org/joda-time/)转成想要的类型。
解释:
时间戳(Timestamp):指格林威治时间(Greenwich Mean Time,GMT, 零时区)1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。编程人员对于这个肯定不陌生,是非常常见的时间类。
Joda-Time:提供了高质量的替代java date和time类的方法。在JAVA SE8官方文档中已经纳入了Joda-Time。
-------------------------------------------
参考:
http://docs.oracle.com/javase/6/docs/api/java/sql/Date.html
http://www.joda.org/joda-time
http://h819.iteye.com/blog/611099
分享到:
相关推荐
java.util.Date与java.sql.Date互转及字符串转换为日期时间格式.docx
详细介绍java.util.Date和java.sql.Date相互转换的多种方法总结,希望对大家有帮助
java_sql_Date与java_util_Date转换
java.sql.date与java.util.date.pdf
类型转换 ( Java.util.date与java.sql.date区别和转换
此java文件包括常用的日期类型之间的转换,包括java.util.Date、java.sql.Date、String之间的任意类型、格式转换......
java.util.Date与java.sql.Date互转及字符串转换为日期时间格式[文].pdf
主要介绍了java.util.Date与java.sql.Date的区别的相关资料,需要的朋友可以参考下
java中util.date和sql.date的类型转换问题.帮助大家很完善的了解关于java日期类型和数据库日期类型转换的问题,很值得拥有.
1、如何将java.util.Date转化为java.sql.Date?转化:java.sql.Date sd;java.util.Date ud;//initialize the ud such as ud = new java.util.Date();sd = new java.sql.Date(ud.getTime());2、如果要插入到数据库...
1.支持java.sql.Date 与 java.util.Date互转 2.支持java.util.Calendar,java.util.Date,java.sql.Date格式化输出 3.支持字符串转java.util.Date 支持字符串格式: yyyyMMdd yyyyMMddHH yyyyMMddHHmm ...
将java.util.Date类型格式化成字符串显示; 将java.sql.Date类型格式化成字符串显示; 将Timestamp类型格式化成字符串显示 将字符串转换成java.util.Date类型 将字符串转换成java.sql.Date类型 将字符串转换成...
import java.sql.Date; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Timestamp; import java.util.ArrayList; import java.util.List; import ...
public java.util.Date getUDate(java.util.Date a); public java.util.Calendar getCalendar(java.util.Calendar a); public java.sql.Timestamp getTimestamp(java.sql.Timestamp a); public java.sql.Date ...
java.util.Date, java.util.Calendar, java.sql.Date, java.sql.Time, java.sql.Timestamp区别和联系
按格式化字符串将 String 类型 转换为 sql.date 注意,非 util.date 可视化字符串例如 "yyyy-MM-dd HH:mm:ss