JPA 映射时间(Temporal)类型@Temporal

在进行实体映射时,有关时间日期类型的类型可以是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”
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值