浅谈其他的Hibernate元数据(Metadata)

来源:岁月联盟 编辑:zhuzhu 时间:2009-09-25

Hibernate元数据有很多值得学习的地方,这里我们主要介绍其他Hibernate元数据(Metadata),包括介绍使用XDoclet 标记等方面

其他Hibernate元数据(Metadata),XML 并不适用于所有人, 因此有其他定义Hibernate O/R 映射元数据(metadata)的方法。

1.Hibernate元数据 使用 XDoclet 标记

很多Hibernate使用者更喜欢使用XDoclet@hibernate.tags将映射信息直接嵌入到源代码中。我们不会在本文档中涉及这个方法,因为严格说来,这属于XDoclet的一部分。然而,我们包含了如下使用XDoclet映射的Cat类的例子。

  1. package eg;  
  2. import java.util.Set;  
  3. import java.util.Date;  
  4.  
  5. /**  
  6.  * @hibernate.class  
  7.  *  table="CATS" 
  8.  */  
  9. public class Cat {  
  10.     private Long id; // identifier  
  11.     private Date birthdate;  
  12.     private Cat mother;  
  13.     private Set kittens  
  14.     private Color color;  
  15.     private char sex;  
  16.     private float weight;  
  17.  
  18.     /*  
  19.      * @hibernate.id  
  20.      *  generator-class="native" 
  21.      *  column="CAT_ID" 
  22.      */  
  23.     public Long getId() {  
  24.         return id;  
  25.     }  
  26.     private void setId(Long id) {  
  27.         this.id=id;  
  28.     }  
  29.  
  30.     /**  
  31.      * @hibernate.many-to-one  
  32.      *  column="PARENT_ID" 
  33.      */  
  34.     public Cat getMother() {  
  35.         return mother;  
  36.     }  
  37.     void setMother(Cat mother) {  
  38.         this.mother = mother;  
  39.     }  
  40.  
  41.     /**  
  42.      * @hibernate.property  
  43.      *  column="BIRTH_DATE" 
  44.      */  
  45.     public Date getBirthdate() {  
  46.         return birthdate;  
  47.     }  
  48.     void setBirthdate(Date date) {  
  49.         birthdate = date;  
  50.     }  
  51.     /**  
  52.      * @hibernate.property  
  53.      *  column="WEIGHT" 
  54.      */  
  55.     public float getWeight() {  
  56.         return weight;  
  57.     }  
  58.     void setWeight(float weight) {  
  59.         this.weight = weight;  
  60.     }  
  61.  
  62.     /**  
  63.      * @hibernate.property  
  64.      *  column="COLOR" 
  65.      *  not-null="true" 
  66.      */  
  67.     public Color getColor() {  
  68.         return color;  
  69.     }  
  70.     void setColor(Color color) {  
  71.         this.color = color;  
  72.     }  
  73.     /**  
  74.      * @hibernate.set  
  75.      *  inverse="true" 
  76.      *  order-by="BIRTH_DATE" 
  77.      * @hibernate.collection-key  
  78.      *  column="PARENT_ID" 
  79.      * @hibernate.collection-one-to-many  
  80.      */  
  81.     public Set getKittens() {  
  82.         return kittens;  
  83.     }  
  84.     void setKittens(Set kittens) {  
  85.         this.kittens = kittens;  
  86.     }  
  87.     // addKitten not needed by Hibernate  
  88.     public void addKitten(Cat kitten) {  
  89.         kittens.add(kitten);  
  90.     }  
  91.  
  92.     /**  
  93.      * @hibernate.property  
  94.      *  column="SEX" 
  95.      *  not-null="true" 
  96.      *  update="false" 
  97.      */  
  98.     public char getSex() {  
  99.         return sex;  
  100.     }  
  101.     void setSex(char sex) {  
  102.         this.sex=sex;  
  103.     }  

参考Hibernate网站更多的Xdoclet和Hibernate的例子

2. Hibernate元数据使用 JDK 5.0 的注解(Annotation)

JDK 5.0 在语言级别引入了 XDoclet 风格的标注,并且是类型安全的,在编译期进行检查。这一机制比XDoclet的注解更为强大,有更好的工具和IDE支持。例如, IntelliJ IDEA,支持JDK 5.0注解的自动完成和语法高亮 。EJB规范的新修订版(JSR-220)使用 JDK 5.0的注解作为entity beans的主要元数据(metadata)机制。

Hibernate 3 实现了JSR-220 (the persistence API)的EntityManager,支持通过Hibernate Annotations包定义映射元数据。这个包作为单独的部分下载,支持EJB3 (JSR-220)和Hibernate3的元数据。

这是一个被注解为EJB entity bean 的POJO类的例子

  1. @Entity(access = AccessType.FIELD)  
  2. public class Customer implements Serializable {  
  3.  
  4.     @Id;  
  5.     Long id;  
  6.  
  7.     String firstName;  
  8.     String lastName;  
  9.     Date birthday;  
  10.  
  11.     @Transient  
  12.     Integer age;  
  13.  
  14.     @Embedded  
  15.     private Address homeAddress;  
  16.  
  17.     @OneToMany(cascade=CascadeType.ALL)  
  18.     @JoinColumn(name="CUSTOMER_ID")  
  19.     Set<Order> orders;  
  20.  
  21.     // Getter/setter and business methods  

注意:

对 JDK 5.0 注解 (和 JSR-220)支持的工作仍然在进行中,并未完成。更多细节请参阅Hibernate Annotations 模块。