继承映射
父类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>
父类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>