hibernate学习笔记 第 1 章 Hibernate入门

 
<hibernate-mapping>

    <class name="events.Event" table="EVENTS">
        <id name="id" column="EVENT_ID">
            <generator class="native"/>
        </id>
        <property name="date" type="timestamp" column="EVENT_DATE"/>
        <property name="title"/>
    </class>

</hibernate-mapping>
嵌套的generator元素指定了标识符生成策略,在这里我们指定native,它根据已配置的数据库(方言)自动选择最佳的标识符生成策略。
timestamp知识:

 
 
在进行实体映射时,有关时间日期类型的类型可以是 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.Datejava.sql.Timejava.sql.Timestamp这三种类型不同,它们表示时间的精确度不同。三者的区别如表所示。

区别java.sql.Datejava.sql.Timejava.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、付费专栏及课程。

余额充值