hibernate注释应用

转自http://blog.csdn.net/mealietree/archive/2007/04/12/1561685.aspx
 现在EJB3实体Bean是纯粹的POJO。实际上表达了和Hibernate持久化实体对象同样的概念。他们的映射都通过JDK5.0注释来定义(EJB3规范中的XML描述语法至今还没有定下来)。注释分为两个部分,分别是逻辑映射注释和物理映射注释,通过逻辑映射注释可用描述对象模型,类之间的关系等等,而物理映射注释则描述了物理的schema,表,列,索引等等。下面外面在代码中将混合使用这两种类型的注释

 

(一)声明实体

@Entity

POJO@Entity进行实体注释

@Table

        @Table是类的一级注释,通过它可用为实体指定表(Table),目录(Catalog),和schema的名字,如果没有@Table,那么系统自动使用默认值:实体的短类名(不带包名)

@Version

        可用在实体Bean中使用@Version添加乐观锁支持。

        根据EJB3规范,Version列可以使用numeric类型(推荐方式)也可以使用timestamp类型。Hibernate支持任何自定义类型,只要该类型实现了UserVersionType.

 

 

Hibernate 支持使用自定义注解来实现实体类和数据库表之间的映射关系。您可以使用 `@javax.persistence.Table` 注解来指定实体类与数据库表之间的映射关系,使用 `@javax.persistence.Column` 注解来指定实体类属性与数据库列之间的映射关系。 例如,如果您想要将一个名为 `Person` 的实体类映射到一个名为 `person_info` 的数据库表上,您可以使用以下注解: ```java @Entity @Table(name = "person_info") public class Person { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "full_name") private String fullName; @Column(name = "age") private int age; // 省略 getter 和 setter 方法 } ``` 在上面的例子中,`@Table(name = "person_info")` 注解指定了 `Person` 实体类与 `person_info` 数据库表之间的映射关系,`@Column(name = "full_name")` 注解指定了 `fullName` 属性与 `full_name` 数据库列之间的映射关系,`@Column(name = "age")` 注解指定了 `age` 属性与 `age` 数据库列之间的映射关系。 您也可以自定义自己的注解来简化实体类的编写工作。例如: ```java @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface EntityMapping { String tableName(); String[] columnNames(); } ``` 上面的代码定义了一个 `@EntityMapping` 注解,用于指定实体类的映射关系。您可以将这个注解应用到实体类上,如下所示: ```java @Entity @EntityMapping(tableName = "person_info", columnNames = {"full_name", "age"}) public class Person { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; private String fullName; private int age; // 省略 getter 和 setter 方法 } ``` 在上面的例子中,`@EntityMapping(tableName = "person_info", columnNames = {"full_name", "age"})` 注解指定了 `Person` 实体类与 `person_info` 数据库表之间的映射关系,以及 `fullName` 和 `age` 属性与数据库表中的哪些列之间的映射关系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值