在进行实体映射时,有关时间日期类型的类型可以是java.sql包下的java.sql.Date、java.sql.Time 和java.sql.Timestamp,还有java.util包下的java.util.Date 和 java.util.Calendar类型。默认情况下,实体中使用的数据类型是java.sql包下的类,但此时如果要使用java.util包中的时间日期类型,则需要而外标注@Temporal注释来说明转化成java.util包中的类型。
例如以下所示,将属性“createTime”创建时间转化为java.util.Date,属性“birthday”出生日期转化为java.util.Date类型,代码如下。
@Entity
@Table(name = "customer")
public class CustomerEO implements java.io.Serializable {
……
private java.util.Date createTime;
@Temporal(TemporalType.TIME)
public java.util.Date getCreateTime() {
return createTime;
}
public void setCreateTime(java.util.Date createTime) {
this.createTime = createTime;
}
private java.util.Date birthday;
@Temporal(TemporalType.DATE)
public java.util.Date getBirthday() {
return birthday;
}
public void setBirthday(java.util.Date birthday) {
this.birthday = birthday;
}
}
其中,使用@Temporal注释时应该注意以下几个问题。
l @Temporal的定义如以下所示。
public @interface Temporal {
TemporalType value() default TIMESTAMP;
}
默认为TemporalType.TIMESTAMP类型。 TemporalType枚举类型定义如下:
public enum TemporalType {
DATE, //java.sql.Date
TIME, //java.sql.Time
TIMESTAMP //java.sql.Timestamp
}
l java.sql.Date、java.sql.Time和java.sql.Timestamp这三种类型不同,它们表示时间的精确度不同。三者的区别如表所示。
表区别java.sql.Date、java.sql.Time和java.sql.Timestamp类型
类型
说明
java.sql.Date 日期型,精确到年月日,例如“2008-08-08”
java.sql.Time 时间型,精确到时分秒,例如“20:00:00”
java.sql.Timestamp 时间戳,精确到纳秒,例如“2008-08-08 20:00:00.000000001”