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