1.两个基础知识
(1)在Java中,代表时间和日期的类型包括:java.util.Date和java.util.Calender
此外,在JDBC API中还提供了3个扩展了java.util.Date类的子类:java.sql.Date;java.sql.Time;java.sql.Timestamp
这三个类分别和标准SQL类型中的DATE,TIME,TIMESTAMP类型对应
(2)在标准SQL中,DATE表示日期、TIME表时间、TIMESTAMP表时间戳(同时包含日期和时间信息)
2.如何进行映射?
(1)因为java.util.Date类是java.sql.Date;java.sql.Time;java.sql.Timestamp三个类的父类,所以java.util.Date可以对应标准SQL类 型中的DATE、TIME、TIMESTAMP。
(2)所以在设置持久化类的DATE类型时,设置为java.util.Date
3.如何把java.util.Date映射为DATE、TIME和TIMESTAMP?
可以通过property的type属性进行映射:
<property name="date" type="date">
<column name="DATE" />
</property>
<property name="date" type="time">
<column name="DATE" />
</property>
<property name="date" type="timestamp">
<column name="DATE" />
</property>
其中timestamp、date、time既不是java类型,也不是标准SQL类型,而是hibernate映射类型。