Java 中的类型
1. java.sql 包下给出三个数据库相关的日期时间类型,分别是
java.sql.Date, 表示日期,只有年月日,没有时分秒.java.sql.Time, 表示时间, 只有时分秒,没有年月日.java.sql.Timestamp, 表示时间戳,有年月日时分秒,以及毫秒.
2. java.util 包下给出的三个与时间相关的类型, 分别是:
java.util.Date, 表示日期,只有年月日,没有时分秒.java.util.Time, 表示时间, 只有时分秒,没有年月日.java.util.Timestamp, 表示时间戳,有年月日时分秒,以及毫秒.
2. 时间类型转换的原因
- DAO 层使用的时间类型来自于
java.sql包下,
而其他层(Service, Servlet)使用的时间类型来自于java.util包下. ResultSet#getDate();返回的是java.sql.Date();PrparedStatement#setDate(int,Date);其中第二个参数是java.sql.Date
3. 时间类型转换
1. java.util 日期类型转换为 java.sql 日期类型
- 把
java.util的日期类型转换成毫秒值; - 将毫秒值传递给对应的构造函数, 创建
java.sql对应的日期类型.
2. java.sql 日期类型转换成 java.util 日期类型
- 这一步不需要处理, 因为
java.sql.Date是java.util.Date的子类.
参考资料: