转Hibernate继承
hibernate继承映射
以下测试是在mysql中进行的。
1、单表方式
Animal.java
- @Entity
- @Inheritance(strategy=InheritanceType.SINGLE_TABLE)
- @DiscriminatorColumn(name="animalType")
- @DiscriminatorValue("animal")
- public class Animal {
- private int id;
- private String name;
- @Id
- @GeneratedValue
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- }
Cat.java
- @Entity
- @DiscriminatorValue("cat")
- public class Cat extends Animal {
- private String catName;
- public String getCatName() {
- return catName;
- }
- public void setCatName(String catName) {
- this.catName = catName;
- }
- }
Dog.java
- @Entity
- @DiscriminatorValue(value="dog")
- public class Dog extends Animal{
- private String dogName;
- public String getDogName() {
- return dogName;
- }
- public void setDogName(String dogName) {
- this.dogName = dogName;
- }
- }
TestJunit.java
- @Test
- public void testAnimal(){
- Animal t = new Animal();
- t.setName("animal");
- session.saveOrUpdate(t);
- }
- @Test
- public void testCat(){
- Cat t = new Cat();
- t.setName("cat");
- t.setCatName("cat");
- session.saveOrUpdate(t);
- }
- @Test
- public void testDog(){
- Dog t = new Dog();
- t.setName("dog");
- t.setDogName("dog");
- session.saveOrUpdate(t);
- }
对应生成的数据表是这样的
table---animal
id | name | animalType | catName | dogName |
1 | animal | animal | null | null |
2 | cat | cat | cat | null |
3 | dog | dog | null | dog |
2、join方式
Animal.java
- @Entity
- @Inheritance(strategy=InheritanceType.JOINED)
- public class Animal {
- private int id;
- private String name;
- @Id
- @GeneratedValue
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- }
Cat.java
- @Entity
- @PrimaryKeyJoinColumn(name="catId")
- public class Cat extends Animal {
- private String catName;
- public String getCatName() {
- return catName;
- }
- public void setCatName(String catName) {
- this.catName = catName;
- }
- }
Dog.java
- @Entity
- @PrimaryKeyJoinColumn(name="dogId")
- public class Dog extends Animal{
- private String dogName;
- public String getDogName() {
- return dogName;
- }
- public void setDogName(String dogName) {
- this.dogName = dogName;
- }
- }
TestJunit.java
- @Test
- public void testAnimal(){
- Animal t = new Animal();
- t.setName("animal");
- session.saveOrUpdate(t);
- }
- @Test
- public void testCat(){
- Cat t = new Cat();
- t.setName("cat");
- t.setCatName("cat");
- session.saveOrUpdate(t);
- }
- @Test
- public void testDog(){
- Dog t = new Dog();
- t.setName("dog");
- t.setDogName("dog");
- session.saveOrUpdate(t);
- }
对应生成的数据表是这样的
table---Animal
id | name |
1 | animal |
2 | cat |
3 | dog |
table---cat
catId | catName |
2 | cat |
table---dog
dogId | dogName |
3 | dog |
3、每个实体类对应一个数据表
以下的测试中,Anamal.java中的主键生成策略需要注解成@GeneratedValue(strategy=GenerationType.TABLE),测试是在mysql数据库中进行的。
Animal.java
- @Entity
- @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
- public class Animal {
- private int id;
- private String name;
- @Id
- @GeneratedValue(strategy=GenerationType.TABLE)
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- }
Cat.java
- @Entity
- @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
- public class Cat extends Animal {
- private String catName;
- public String getCatName() {
- return catName;
- }
- public void setCatName(String catName) {
- this.catName = catName;
- }
- }
Dog.java
- @Entity
- @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
- public class Dog extends Animal{
- private String dogName;
- public String getDogName() {
- return dogName;
- }
- public void setDogName(String dogName) {
- this.dogName = dogName;
- }
- }
TestJunit.java
- @Test
- public void testAnimal(){
- Animal t = new Animal();
- t.setName("animal");
- session.saveOrUpdate(t);
- }
- @Test
- public void testCat(){
- Cat t = new Cat();
- t.setName("cat");
- t.setCatName("cat");
- session.saveOrUpdate(t);
- }
- @Test
- public void testDog(){
- Dog t = new Dog();
- t.setName("dog");
- t.setDogName("dog");
- session.saveOrUpdate(t);
- }
对应生成的数据表是这样的
table---animal
id | name |
1 | animal |
table---cat
id | name | catName |
2 | cat | cat |
table---dog
id | name | dogName |
3 | dog | dog |
转Hibernate继承的更多相关文章
- hibernate继承(转)
http://justsee.iteye.com/blog/1070588 一.继承关系_整个继承树映射到一张表 对象模型(Java类结构) 一个类继承体系一张表(subclass)(表结构) Emp ...
- 【JavaEE】Hibernate继承映射,不用多态查询只查父表的方法
几个月前,我在博问里面发了一个问题:http://q.cnblogs.com/q/64900/,但是一直没有找到好的答案,关闭问题以后才自己解决了,在这里分享一下. 首先我重复一下场景,博问里面举的动 ...
- SSH开发实践part3:hibernate继承映射
0 大家好.上次讲了关于hibernate中双向1-N的映射配置,可以参考:http://www.cnblogs.com/souvenir/p/3784510.html 实际项目中,对象间的关系比较复 ...
- Hibernate继承映射
在面向对象的程序领域中,类与类之间是有继承关系的,例如Java世界中只需要extends关键字就可以确定这两个类的父子关系,但是在关系数据库的世界中,表与表之间没有任何关键字可以明确指明这两张表的父子 ...
- web进修之—Hibernate 继承映射(5)
先看三个类的继承关系,Payment是父类,CashPayment和CreditCardPayment是Payment的子类: view plaincopy to clipboardprint p ...
- Hibernate继承类的实现
版权声明:本文为博主原创文章,如需转载请标注转载地址. 博客地址:http://www.cnblogs.com/caoyc/p/5603724.html 对于继承关系类的映射.比如在论坛中文章(Ar ...
- hibernate 继承映射关系( SINGLE_TABLE)
三种继承映射关系. 1,SINGLE_TABLE person student teacher 在一个表中,student和teacher继承自person,通过一个Discriminato ...
- Hibernate 继承映射可能会遇到的错误
问题: 我们在配置hibernate的时候,默认是会配置下面的两个属性的 <property name="hibernate.default_catalog">hibe ...
- Hibernate继承注解
hibernate应用中,继承的用途或目的主要有两点: 组件化:故明思义,把重复性的代码抽取成组件,以便重用和维护.hibernate应用中,一些重复的字段,重复的映射配置,就需要抽取成组件. 多态性 ...
随机推荐
- Chosen:Select 选择框的华丽变身
HTML Form 表单里的各种组件,例如文本输入框,textarea,按钮等,都可以通过CSS或其它技术进行美化,让它们看起来很漂亮了,唯独下拉列表选项框(select box),不管你怎么做,它摆 ...
- 跨域-jsonp、cors、iframe、document.domain、postMessage()
同源策略 概念:同源: 协议.域名.端口号 完全相同 同源策略是浏览器的一种安全策略:且浏览器不会将违反同源策略的响应信息返回 http://127.0.0.1:3000/index.html ...
- 错误:java.lang.IllegalArgumentException: Receiver not registered
Caused by: java.lang.IllegalArgumentException: Receiver not registered: com.multak.cookaraclient.Mai ...
- SQL Server中怎样可以从SELECT语句的结果集中删除重复行
首先要分析出现重复记录的原因,是不是有一些where条件没有加上,把该加的条件都加上如果还有结果集重复,考虑以下方法去重: 结果集中去除重复行可以使用函数[distinct]也可以使用分组语句[gro ...
- [转]opencv学习资料
转自:http://blog.csdn.net/poem_qianmo/article/details/20537737 1:Mat imread(const string& filename ...
- Book 动态规划
虽然之前学过一点点,但是还是不会------现在好好跟着白书1.4节学一下—————— (1)数字三角形 d(i,j) = max(d(i+1,j),d(i+1,j+1)) + a[i][j] hdu ...
- Codeforces Round #284 (Div. 2) A
解题思路:给出 n个电影的精彩时段(a[i],b[i]),和每次可以跳过的时间x,问要看完所有的精彩时刻,至少需要看多长时间的电影. 因为要时间最少,所有除了精彩时刻的电影则能跳过就跳过(用取余来算) ...
- async-validator 的中文文档翻译
阿里出品的 antd 和 ElementUI 组件库中表单校验默认使用的 async-validator,它在 gitbub 上也获得了 3.8k 的 star,可见这个库十分强大,奈何只有英文文档看 ...
- POJ 1988 Cube Stacking( 带权并查集 )*
POJ 1988 Cube Stacking( 带权并查集 ) 非常棒的一道题!借鉴"找回失去的"博客 链接:传送门 题意: P次查询,每次查询有两种: M x y 将包含x的集合 ...
- HDU 5776 sum( 鸽巢定理简单题 )
链接:传送门 题意:给一个长为 n 的串,问是否有子串的和是 m 的倍数. 思路:典型鸽巢定理的应用,但是这里 n,m 的大小关系是不确定的,如果 n >= m 根据定理可以很简单的判定是一定有 ...