Hibernate旅程(六)Hibernate映射–继承映射
最后更新于:2022-04-01 14:49:57
上篇主要讲述了[hibernate的对象关系映射](http://blog.csdn.net/lovesummerforever/article/details/20901011)。本篇讲述对象继承关系是如何映射具体的表。
对于继承类映射到表有三种方式:
1、一棵继承树映射一张表。
2、每个子类各自映射表。
3、继承树的每个类各自映射表。
### 1、一棵继承树一张表。
直接上图,如下图所示。
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-06-21_576908bd3c71f.jpg)
映射文件代码如下所示。
~~~
<hibernate-mapping package="com.bjpowernode.hibernate">
<class name="Animal" table="t_animal" lazy="false">
<id name="id">
<generator class="native"/>
</id>
<discriminator column="type" type="string">
</discriminator>
<property name="name"/>
<property name="sex"/>
<subclass name="Pig" discriminator-value="P">
<property name="weight"/>
</subclass>
<subclass name="Bird" discriminator-value="B">
<property name="height"/>
</subclass>
</class>
</hibernate-mapping>
~~~
### 2、每个子类一张表。
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-06-21_576908f94d034.jpg)
映射文件代码如下所示。
~~~
<!--加上package,所以不用写完整了.-->
<hibernate-mapping package="com.bjpowernode.hibernate">
<class name="Animal" table="t_animal" abstract="true">
<id name="id">
<generator class="assigned"/>
</id>
<property name="name"/>
<property name="sex"/>
<union-subclass name="Pig" table="t_pig">
<property name="weight"/>
</union-subclass>
<union-subclass name="Bird" table="t_bird">
<property name="height"/>
</union-subclass>
</class>
</hibernate-mapping>
~~~
### 3、每个类一张表(子类+父类)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-06-21_576908f9661c0.jpg)
代码如下所示。
~~~
<hibernate-mapping package="com.bjpowernode.hibernate">
<class name="Animal" table="t_animal" lazy="false">
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<property name="sex"/>
<joined-subclass name="Pig" table="t_pig">
<!-- 将会在pig表中加上一个pid -->
<key column="pid"/>
<property name="weight"/>
</joined-subclass>
<joined-subclass name="Bird" table="t_bird">
<!-- 将会在pig表中加上一个pid -->
<key column="bid"/>
<property name="height"/>
</joined-subclass>
</class>
</hibernate-mapping>
~~~
以上三种策略,各有优缺点:
单表继承。查询速度最快,效率高,但是存在冗余字段。
类表继承。层次清楚,无冗余;但是如果使用自增主键方式会产生重复主键。需要使用手动分配主键。
具体表继承。层次最明了,这是优点,也是缺点,而且数据操作效率不高!