web进修之—Hibernate 继承映射(5)
先看三个类的继承关系,Payment是父类,CashPayment和CreditCardPayment是Payment的子类:
- public class Payment {
- protected long id;
- private String amount;
- // setter,getter
- }
- public class CashPayment extends Payment {
- private String cashType;
- // setter,getter
- }
- public class CreditCardPayment extends Payment {
- private String creditCardType;
- // setter,getter
- }
public class Payment {
protected long id;
private String amount;
// setter,getter
}
public class CashPayment extends Payment {
private String cashType;
// setter,getter
}
public class CreditCardPayment extends Payment {
private String creditCardType;
// setter,getter
}
每个类分层结构一张表
一个父类和他的所有子类共用一张表,父类的id是主键,在数据库中就是这些类的字段都在一张表中。因为对于子类之间来说,子类CraditCardPayment没有子类CashPayment的cashType属性,所以在数据库中的那一列就是NUll,所以映射的时候所有子类的列不能设置not null约束。
每个子类一张表
父类、子类都各有各自的表,子类的表里面只有子类的属性,子类的表通过主键关联到父类的表的主键,相当于子类相对于父类是单向一对一,子类增加一条记录,弗雷跟着增加一条记录。
每个子类对应一张表,但是使用标识(Discriminator)
这样子就可以由父类的记录找到子类的记录。和上面的区别就是在父类的表里面添加了一个标志字段:用来标识是哪一个子类。
混合使用每个类一张表和父子类共用一张表
就是CraditCardPayment单独一张表,CashPayment和父类一张表,也要使用Discriminator。
每个具体类一张表
父类、每个子类对应一张表。子类的表也保存从父类继承来的属性,所有类公用一个id,也就是各个表里面的id是连续的,表之间没有关联关系。这种方式的局限在于,如果一个属性在超类中做了映射,其字段名必须与所有子类表中定义的相同。
每个具体类一张表,使用隐式多态
每个子类一张表,父类没有表,不能直接保存一个父类,也不能保存这种方法的缺陷在于,在 Hibernate 执行多态查询时(polymorphic queries)无法生成带 UNION 的 SQL 语句。
不论使用哪一种方法映射,配置文件都是写在父类Payment的映射文件里面,payment.hbm.xml如下:
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
- <hibernate-mapping package="org.lep.hibernate.model" >
- <class name="Payment" >
- <id name="id" column="payment_id">
- <generator class="increment"/>
- </id>
- <!--父类中的属性-->
- <property name="amount" type="string" column="amount"/>
- <!--所有类共用一张表 start-->
- <!--用来辨识是那一个类的属性,该字段的取值为PAYMENT、CREDIT或者CASH(如果某一个类没有设置discriminator-valur,默认为该类的全限定名)-->
- <!--<discriminator column="payment_type" type="string"></discriminator>-->
- <!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
- <!--<!–子类中的属性–>-->
- <!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
- <!--</subclass>-->
- <!--<subclass name="CashPayment" discriminator-value="CASH">-->
- <!--<property name="cashType" column="cash_type"></property>-->
- <!--</subclass>-->
- <!--所有类共用一张表 end-->
- <!--每个子类一张表 start-->
- <!--<joined-subclass name="CreditCardPayment">-->
- <!--<key column="payment_id"></key>-->
- <!--<property name="creditCardType" />-->
- <!--</joined-subclass>-->
- <!--<joined-subclass name="CashPayment">-->
- <!--<key column="payment_id"></key>-->
- <!--<property name="cashType" />-->
- <!--</joined-subclass>-->
- <!--每个子类一张表 end-->
- <!--每个子类一张表,使用辨识标志 start-->
- <!--用来辨识是那一个类的属性,该字段的取值为PAYMENT、CREDIT或者CASH(如果某一个类没有设置discriminator-valur,默认为该类的全限定名)-->
- <!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
- <!--<!–fetch="select"表示在查询payment的时候,不进行外表链接查询CreditCardPayment–>-->
- <!--<join table="CreditCardPayment" fetch="select">-->
- <!--<key column="payment_id"></key>-->
- <!--<!–子类中的属性–>-->
- <!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
- <!--</join>-->
- <!--</subclass>-->
- <!--<subclass name="CashPayment" discriminator-value="CASH">-->
- <!--<join table="CashPayment">-->
- <!--<key column="payment_id"></key>-->
- <!--<!–子类中的属性–>-->
- <!--<property name="cashType" column="cash_type"></property>-->
- <!--</join>-->
- <!--</subclass>-->
- <!--所有类共用一张表,使用辨识标志 end-->
- <!--混合使用每个子类一张表和每个分层结构一张表 start-->
- <!--<discriminator column="PAYMENT_TYPE" type="string"/>-->
- <!--<!–使用每个分层结构一章表–>-->
- <!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
- <!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
- <!--</subclass>-->
- <!--<!–使用每个子类一张表–>-->
- <!--<subclass name="CashPayment" discriminator-value="CASH">-->
- <!--<join table="CashPayment">-->
- <!--<key column="payment_id"></key>-->
- <!--<!–子类中的属性–>-->
- <!--<property name="cashType" column="cash_type"></property>-->
- <!--</join>-->
- <!--</subclass>-->
- <!--混合使用每个子类一张表和每个分层结构一张表 end-->
- <!--每个具体类一张表 start-->
- <union-subclass name="CreditCardPayment" table="CreditCardPayment">
- <property name="creditCardType" column="credit_cardt_ype"></property>
- </union-subclass>
- <union-subclass name="CashPayment" table="CashPayment">
- <property name="cashType" column="cash_type"></property>
- </union-subclass>
- <!--每个具体类一张表 end-->
- </class>
- <!--每个具体类一张表,使用隐式多态,将父类的属性映射到子类的表里 start-->
- <!--<class name="CreditCardPayment" table="CreditCardPayment">-->
- <!--<id name="id" column="payment_id">-->
- <!--<generator class="increment"/>-->
- <!--</id>-->
- <!--<!–父类中的属性–>-->
- <!--<property name="amount" type="string" column="amount"/>-->
- <!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
- <!--</class>-->
- <!--<class name="CashPayment" table="CashPayment">-->
- <!--<id name="id" column="payment_id">-->
- <!--<generator class="increment"/>-->
- <!--</id>-->
- <!--<!–父类中的属性–>-->
- <!--<property name="amount" type="string" column="amount"/>-->
- <!--<property name="cashType" column="cash_type"></property>-->
- <!--</class>-->
- <!--每个具体类一张表,使用隐式多态 end-->
- </hibernate-mapping>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"><hibernate-mapping package="org.lep.hibernate.model" >
<class name="Payment" >
<id name="id" column="payment_id">
<generator class="increment"/>
</id>
<!--父类中的属性-->
<property name="amount" type="string" column="amount"/><!--所有类共用一张表 start-->
<!--用来辨识是那一个类的属性,该字段的取值为PAYMENT、CREDIT或者CASH(如果某一个类没有设置discriminator-valur,默认为该类的全限定名)-->
<!--<discriminator column="payment_type" type="string"></discriminator>-->
<!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
<!--<!–子类中的属性–>-->
<!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
<!--</subclass>-->
<!--<subclass name="CashPayment" discriminator-value="CASH">-->
<!--<property name="cashType" column="cash_type"></property>-->
<!--</subclass>-->
<!--所有类共用一张表 end--><!--每个子类一张表 start-->
<!--<joined-subclass name="CreditCardPayment">-->
<!--<key column="payment_id"></key>-->
<!--<property name="creditCardType" />-->
<!--</joined-subclass>-->
<!--<joined-subclass name="CashPayment">-->
<!--<key column="payment_id"></key>-->
<!--<property name="cashType" />-->
<!--</joined-subclass>-->
<!--每个子类一张表 end--><!--每个子类一张表,使用辨识标志 start-->
<!--用来辨识是那一个类的属性,该字段的取值为PAYMENT、CREDIT或者CASH(如果某一个类没有设置discriminator-valur,默认为该类的全限定名)-->
<!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
<!--<!–fetch="select"表示在查询payment的时候,不进行外表链接查询CreditCardPayment–>-->
<!--<join table="CreditCardPayment" fetch="select">-->
<!--<key column="payment_id"></key>-->
<!--<!–子类中的属性–>-->
<!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
<!--</join>--><!--</subclass>-->
<!--<subclass name="CashPayment" discriminator-value="CASH">-->
<!--<join table="CashPayment">-->
<!--<key column="payment_id"></key>-->
<!--<!–子类中的属性–>-->
<!--<property name="cashType" column="cash_type"></property>-->
<!--</join>--><!--</subclass>-->
<!--所有类共用一张表,使用辨识标志 end--><!--混合使用每个子类一张表和每个分层结构一张表 start-->
<!--<discriminator column="PAYMENT_TYPE" type="string"/>-->
<!--<!–使用每个分层结构一章表–>-->
<!--<subclass name="CreditCardPayment" discriminator-value="CREDIT">-->
<!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
<!--</subclass>-->
<!--<!–使用每个子类一张表–>-->
<!--<subclass name="CashPayment" discriminator-value="CASH">-->
<!--<join table="CashPayment">-->
<!--<key column="payment_id"></key>-->
<!--<!–子类中的属性–>-->
<!--<property name="cashType" column="cash_type"></property>-->
<!--</join>--><!--</subclass>-->
<!--混合使用每个子类一张表和每个分层结构一张表 end--><!--每个具体类一张表 start-->
<union-subclass name="CreditCardPayment" table="CreditCardPayment">
<property name="creditCardType" column="credit_cardt_ype"></property>
</union-subclass>
<union-subclass name="CashPayment" table="CashPayment">
<property name="cashType" column="cash_type"></property>
</union-subclass>
<!--每个具体类一张表 end-->
</class><!--每个具体类一张表,使用隐式多态,将父类的属性映射到子类的表里 start-->
<!--<class name="CreditCardPayment" table="CreditCardPayment">-->
<!--<id name="id" column="payment_id">-->
<!--<generator class="increment"/>-->
<!--</id>-->
<!--<!–父类中的属性–>-->
<!--<property name="amount" type="string" column="amount"/>-->
<!--<property name="creditCardType" column="credit_cardt_ype"></property>-->
<!--</class>-->
<!--<class name="CashPayment" table="CashPayment">-->
<!--<id name="id" column="payment_id">-->
<!--<generator class="increment"/>-->
<!--</id>-->
<!--<!–父类中的属性–>-->
<!--<property name="amount" type="string" column="amount"/>-->
<!--<property name="cashType" column="cash_type"></property>-->
<!--</class>-->
<!--每个具体类一张表,使用隐式多态 end-->
</hibernate-mapping>
web进修之—Hibernate 继承映射(5)的更多相关文章
- web进修之—Hibernate 关系映射(3)
概述 Hibernate的关系映射是Hibernate使用的难点或者是重点(别担心,不考试哦~),按照不同的分类方式可以对这些映射关系做一个分类,如: 按对象对应关系分: 一对一 多对一/一对多 多对 ...
- web进修之—Hibernate起步(1)(2)
想开始写博客了,尝试了CSDN和cnblog之后还是觉得cnblog更加简洁.专注(不过cnblog不支持搬家),所以把刚刚写的两篇学习博客链接放在这儿,这样这个系列也算是完整了: web进修之—Hi ...
- 【JavaEE】Hibernate继承映射,不用多态查询只查父表的方法
几个月前,我在博问里面发了一个问题:http://q.cnblogs.com/q/64900/,但是一直没有找到好的答案,关闭问题以后才自己解决了,在这里分享一下. 首先我重复一下场景,博问里面举的动 ...
- hibernate 继承映射关系( SINGLE_TABLE)
三种继承映射关系. 1,SINGLE_TABLE person student teacher 在一个表中,student和teacher继承自person,通过一个Discriminato ...
- Hibernate继承映射(@Inheritance)
继承映射在 Annotation 中使用 @Inheritance 注解,并且需要使用 strategy 属性指定继承策略,继承策略有 SINGLE_TABLE.TABLE_PER_CLASS 和 J ...
- SSH开发实践part3:hibernate继承映射
0 大家好.上次讲了关于hibernate中双向1-N的映射配置,可以参考:http://www.cnblogs.com/souvenir/p/3784510.html 实际项目中,对象间的关系比较复 ...
- Hibernate继承映射
在面向对象的程序领域中,类与类之间是有继承关系的,例如Java世界中只需要extends关键字就可以确定这两个类的父子关系,但是在关系数据库的世界中,表与表之间没有任何关键字可以明确指明这两张表的父子 ...
- web进修之—Hibernate 类型(4)
本片包含Hibernate的两种类型的简单介绍和集合类型的映射. Hibernate中的两种类型: Entity 自己掌控自己的生命周期,比如Person有addrss属性(关联到另外一张表).age ...
- web进修之—Hibernate HQL(7)
概述 HQL是Hibernate封装成为面向对象的数据库查询语言,具有如下特点: 面向对象,包括继承.多态和关联之类的概念,SQL操作的数据库的表,HQL更像是操作对象 大小写敏感,只对对象和属性敏感 ...
随机推荐
- 更适用于JavaScript的设计模式:面向委托的设计,了解一下?(下)
先来看一下传统的面向类式的写法: function Foo(name) { this.name = name; } Foo.prototype.sayName = function() { conso ...
- Linux学习---内存分布基础
内核空间 应用程序不允许访问 -----------------------------------------3G 栈空间 局部变量 RW ----------------------------- ...
- C#遍历SharePoint文档库下所有文档包括文档库中子文件夹下所有文档
/// <summary> /// 获取取子文件下所有文件 /// </summary> /// <param name="web"></ ...
- oracle odbc mysql 字段不全
主要是字段集不对,mysql的字符集默认设置为utf8,odbc才是unicode编码连接,无法转发.选择ansi连接方式即可.
- 一. IntelliJ IDEA详细配置文档之初始环境搭建
前言 对于用惯了eclipse的同学来说, 突然切换为idea不是一件那么容易的事情, 所以我会发布一系列只讲解idea使用技巧的文章, 请大家多多关注. 本系列文章的配置参考网上某教程的讲解, 本 ...
- java开发师笔试面试每日12题(3)
1.JDK和JRE的区别是什么? Java运行时环境(JRE)是将要执行Java程序的Java虚拟机.它同时也包含了执行applet需要的浏览器插件.Java开发工具包(JDK)是完整的Java软件开 ...
- VS中Debug与Release、_WIN32与_WIN64的区别
一.Debug与Release 1. 区别 Debug——调试版,生成的.exe中包含很多调试信息,若直接发包,比较大: Release——发布版 2. 如何区分是Debug编译还是Release ...
- 我的C#跨平台之旅(二):开发最为简单的REST API
添加NuGet引用:Microsoft.AspNet.WebApi.Owin 在启动类启用WebApi: 添加一个Controller类,代码如下: 运行程序并访问:http://localhost: ...
- Servlet发送邮件遇到的问题SMTPSendFailedException 554
接到通知,一个接收用户请求的邮箱有段时间收不到邮件了.当时想着这么简单的功能,就没有加上日志记录.重写程序后,日志记下的报错是:SMTP的SMTPSendFailedException 554 co ...
- day_7数据类型的相互转换,与字符编码
首先复一下昨天的内容 1:深浅拷贝 1:值拷贝 直接赋值 列表1=列表2 列表1中的任何值发生改变,列表2中的值都会随之改变 2:浅拷贝,列表2=列表1 列表1中存放的值的地址没有改变, ...