Hibernate @Temporal

     (1) 如果在某类中有Date类型的属性,数据库中存储可能是'yyyy-MM-dd hh:MM:ss'要在查询时获得年月日,在该属性上标注@Temporal(TemporalType.DATE) 会得到形如'yyyy-MM-dd' 格式的日期。

      (2)如果在某类中有Date类型的属性,数据库中存储可能是'yyyy-MM-dd hh:MM:ss'要获得时分秒,在该属性上标注 @Temporal(TemporalType.TIME) 会得到形如'HH:MM:SS' 格式的日期。

      (3)如果在某类中有Date类型的属性,数据库中存储可能是'yyyy-MM-dd hh:MM:ss'要获得'是'yyyy-MM-dd hh:MM:ss',在该属性上标注@Temporal(TemporalType.TIMESTAMP) 会得到形如'HH:MM:SS' 格式的日期。

注:以下Date 均为java.util.Date,time相应字段均用SomeTime代替。

@Temporal(TemporalType.DATE)
@Column(name = "SomeTime")
public Date getSomeTime()
{
return SomeTime;
}

public void setSomeTime(Date SomeTime)
{
this.SomeTime = SomeTime;
}

 

@Temporal(TemporalType.TIMESTAMP)
@Column(name = "Some_Time")
public Date getSomeTime()
{
return  SomeTime;
}

public void setSomeTime(Date SomeTime)
{
this.SomeTime = SomeTime;
}

 

使用@Temporal注释时应该注意以下几个问题。

@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

}

    java.sql.Date、java.sql.Time和java.sql.Timestamp这三种类型不同,它们表示时间的精确度不同。三者的区别如表所示。

 

     类型                        说明
java.sql.Date               日期型,精确到年月日,例如“yyyy-mm-dd”

java.sql.Time               时间型,精确到时分秒,例如“hh:mm:ss”

java.sql.Timestamp      时间戳,精确到纳秒,例如“yyyy-mm-dd hh:mm:ss.000000001”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值