【SSH快速进阶】——Hibernate继承映射:每个具体类映射一张表

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/details/50703988

  上篇文章说的是每个类映射一张表,不管是父类还是子类。与上篇文章不同的是,这里是每个“具体类”映射一张表,什么意思呢?就是让每个子类(具体的、有意义的类)映射一张表。

场景


  与上篇文章场景一样,如下类图

  上图中Pig类和Bird类继承Animal类,要让每个具体类映射一张表,就是只映射Pig和Bird,如下表所示:

                       (表 1)

  上面的表有个特点就是,t_pig和t_bird的主键永远都不会相同。因为表面上看起来这是两张表,但实际上存储的都是动物(同一类型),所以还可以看做是一张表。

配置


PO对象

  这里采用uuid的主键生成策略,父类Animal的id为String类型,其他实体类没有任何变化。(当然也可以用其他生成策略比如assigned等)

  Animal.java

public class Animal {
    private String id;
    private String name;
    private boolean sex;
    //getter、setter
}

  Bird.java

public class Bird extends Animal{
    private int height;
    //getter、setter
}

  Pig.java

public class Pig extends Animal{
    private int weight;
    //getter、setter
}

映射文件

  配置映射文件时,父类还用<class>标签来定义即可;用<union-subclass>标签定义两个子类,且每个类对应的表的信息是完全的,包含了所有从父类继承下来的属性。子类的特有属性同样用<property>定义即可。用abstract属性表示父类Animal为抽象类,这样Animal就不会映射成表了。

  Extends.hbm.xml

<hibernate-mapping package="com.danny.hibernate">
    <class name="Animal" abstract="true">
        <id name="id">
            <generator class="uuid"/>
        </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>

  在配置文件中 <union-subclass>标签中不需要key值了,而且Animal的主键生成策略不能是自增(native)了,如果自增的话,pig表中第一条记录id为1,bird表中第一条记录也为1,而它们在实际意义上属于同一类型(可以看做在一张表中),否则可能造成不同子类对应表中的主键相同,所以主键不可一致。

  启动程序执行的建表语句如下:

drop table if exists t_bird
drop table if exists t_pig
create table t_bird (id integer not null, name varchar(255), sex bit, height integer, primary key (id))
create table t_pig (id integer not null, name varchar(255), sex bit, weight integer, primary key (id))

测试


  对对象的操作同上篇文章《【SSH快速进阶】——Hibernate继承映射:每棵继承树映射一张表》中的测试一致。

  这种方案相对于上层实现(增删改查等操作)基本不变,对象模型父类Animal的主键为String类型(要是int类型则主键生成策略不能设设置为自增(native),这时需要添加的时候手动设置主键。

总结


  此方案跟上篇文章的方案差不多,这里还有一个缺点就是主键不能自增。

【Hibernate继承映射综合分析】

  如果系统需要经常进行查操作且子类数量较多,则建议用第一种方案,即每棵生成树映射一张表,这也是最常用的方法,效率较高。

  如果追求细粒度的设计且子类数量不多,则可以用后两种方案:每个类映射一张表或每个具体类映射一张表。


【 转载请注明出处——胡玉洋《【SSH快速进阶】——Hibernate继承映射:每个具体类映射一张表》】

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏极客慕白的成长之路

关系代数运算方法

在Client与Viewing的clientNo相同情况下,罗列出clientNo,fNale,lName,propertyNo,comment

784
来自专栏互联网高可用架构

伪共享和缓存行

1532
来自专栏debugeeker的专栏

《coredump问题原理探究》Linux x86版6.5节虚函数的coredump例子

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/xuzhina/article/detai...

800
来自专栏木头编程 - moTzxx

ThinkPHP 框架下 BaseModel 类整理

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011415782/article/de...

1212
来自专栏Jed的技术阶梯

Hive窗口函数01-SUM、MIN、MAX、AVG

order by : 在同一个组内,先累加完相同createtime的pv,再累加其他createtime的pv, 比如 : 现在在表末尾加一条数据cooki...

2933
来自专栏云霄雨霁

范式总结

1404
来自专栏java一日一条

简单理解倒排索引

倒排索引从逻辑结构和基本思路上来讲非常简单。下面我们通过具体实例来进行说明,使得读者能够对倒排索引有一个宏观而直接的感受。假设文档集合包含五个文档,每个文档内容...

1052
来自专栏鸿的学习笔记

records包源码解析

核心类有三个 Record, RecordCollection, Database。在做源码分析时,先从入口类Database开始:

712
来自专栏技术沉淀

命令行工具:awk文本处理

1673
来自专栏JackieZheng

Nutch源码阅读进程2---Generate

继之前仓促走完nutch的第一个流程Inject后,再次起航,Debug模式走起,进入第二个预热阶段Generate~~~ 上期回顾:Inject主要是将爬取列...

1957

扫码关注云+社区