hibernate学习3

继承映射
父类Product(int id, String name)
子类一Book(int pageCount)
子类二Clothes(int size)

第一种方法
创建两个表,同普通映射一样
Book (id,name,pageCount)
Clothes(id,name,size)

第二种,每个子类对应一张子表,并与主类共享主表,子表与主表通过外键关联
Product(id,name)
Book(id,pageCount) foreignkey ("id") reference Product("di")
Clothes(id,size) foreignkey ("id") reference Product("di")
映射文件只映射父类
<class name="com.limf.bean.Product" table="Product">
      <id name="id">
         <generator class="native"></generator>
      </id>

      <property name="name" column="name" type="String"/>


      <joined-subclass name="com.limf.bean.Book" table="Book">
          <key column="id"/>    <!--key为外键-->
          <property name="pageCount"/>
      </joined-subclass>

      <joined-subclass name="com.limf.bean.Book" table="Book">
          <key column="id"/>
          <property name="size"/>
      </joined-subclass>

</class>

session.save(new Book())会分别向product表和book表各自插入一条数据


第三种,一个表对应多个类
只有一个Product表,包含所有字段,外加一个类型字段区分
Product(id,name,pageCount,size,category)
映射文件写法:
<class name="com.limf.bean.Product" table="Product">
      <id name="id">
         <generator class="native"></generator>
      </id>

       <!--区分,书写位置在property上面-->
      <discriminator column="category" type="String"/>    
      <property name="name" column="name" type="String"/>

      <!--区分的值为1-->
      <subclass name="com.limf.bean.Book" discriminator-value="1">
         <property name="pageCount" column="pageCount"/>
      </subclass>

      <subclass name="com.limf.bean.Clothes" discriminator-value="2">
         <property name="size" column="size"/>
      </subclass>

</class>

你可能感兴趣的:(Hibernate)