程序员人生 网站导航

【SSH系列】Hibernate映射 -- 继承映射

栏目:框架设计时间:2016-07-21 09:10:21

开篇前言

在前面的博文中,小编介绍了hibernate中的映照,1对1,1对多,多对多,单向,双向等,今天这篇博文,小编主要来介绍1下hibernate中的继承映照,小火伴都知道在C#中,如果想要实现继承,直接在子类中添加冒号便可继承父类,在java中可以用关键字extends实现,那末在hibernate中,甚么是继承映照呢?继承映照的方式又是甚么?继承映照具有几种策略呢?不同策略之间又存在着怎样样的区分和联系呢?该博文,小编就来简单的总结1下hibernate中的继承映照。

继承映照是甚么

首先,我们来看这样的1张表结构:

      

上述的表结构就是继承映照的1种,小猪猪和小鸟鸟他们共用了字段Name和Sex,除此以外,有些字段是针对某种数据而存在的,所以在数据库中为空,如上所,weight是针对小猪猪而言的,而height是针对小鸟鸟而言的,从上面的表结构,我们可以得出,有些字段是共用的,有些字段是自己独有的,她们通过type这个字段来进行区分,ok,小编相信,小火伴们现在对继承映照已有了1定的了解,接着小编来介绍继承映照的方式。   

  继承映照方式

在前面的博文中,小编提到过,c#和java中的继承,但是在数据库的世界中,表之间是没有任何关键字可以明确指明这两张表的父子关系,表与表是没有继承关系这样的说法的。为了将程序领域中的继承关系反应到数据中,Hibernate为我们提供了3种策略,分别是:
a、每颗类继承树1张表;
b、每一个类1张表;
c、每一个具体类1张表;
我们仍然从uml入手,看对象模型,以下所示:

Pig和Bird都继承Animal,她们都有id,name,sex,但是Pig主要看weight,而Bird主要看height,此时如果把这些数据存入到数据库中,可以有3种方案,也就是3种策略。ok,接下来结合Animal这个例子,分别对3种策略进行讲授。
第1种、每颗类继承树1张表
这类方式,只生成1个table,对应的继承映照策略是“单表继承”。如图:   


每颗类继承树1张表,也就是使用1张表表示所有继承体系下的类的属性的并集,这类策略是使用<subclass>标签来实现的。由于类继承体系下会有许多个子类,要把多个类的信息寄存在1张表中,必须有某种机制来辨别哪些记录是属于哪一个类的。Hibernate中的这类机制就是,在表中添加1个字段,用这个字段的值来进行辨别。在表中添加这个标示列使用<discriminator>标签来实现,hbm.xml文件以下所示:

<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping⑶.0.dtd"> <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"/> <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种、每一个类1张表

这类方式,每一个类生成1个table,对应的继承策略是“类表继承”。如图:

这类策略是使用<joined-subclass>标签来定义子类的。父类、子类都对应1张数据库表。在父类对应的数据库表中,它存储了所有记录的公共信息,实际上该父类对应的表会包括所有的记录,包括父类和子类的记录;在子类对应的数据库表中,这个表只定义了子类中所独有的属性映照的字段。子类对应的数据表与父类对应的数据表,通过1对1主键关联的方式关联起来。Hbm.xml文件以下所示:

<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping⑶.0.dtd"> <hibernate-mapping package="com.bjpowernode.hibernate"> <class name="Animal" table="t_animal"> <id name="id"> <generator class="native"/> </id> <property name="name"/> <properties name="sex"/> <joined-subclass name="Pig" table="t_pig"> <key column ="pid"/> <property name="weight"/> </joined-subclass> <joined-subclass name="Bird" table="t_bird"> <key column = "bird"/> <property name="height"/> </joined-subclass> </class> </hibernate-mapping>
第3种、每一个具体类1张表
这类方式,生成3张表,对应的策略是“具体表继承”,以下图所示:

------分隔线----------------------------
------分隔线----------------------------

最新技术推荐