hibernate继承映射 
以下测试是在mysql中进行的。

1、单表方式 
Animal.java

  1. @Entity
  2. @Inheritance(strategy=InheritanceType.SINGLE_TABLE)
  3. @DiscriminatorColumn(name="animalType")
  4. @DiscriminatorValue("animal")
  5. public class Animal {
  6. private int id;
  7. private String name;
  8. @Id
  9. @GeneratedValue
  10. public int getId() {
  11. return id;
  12. }
  13. public void setId(int id) {
  14. this.id = id;
  15. }
  16. public String getName() {
  17. return name;
  18. }
  19. public void setName(String name) {
  20. this.name = name;
  21. }
  22. }

Cat.java

  1. @Entity
  2. @DiscriminatorValue("cat")
  3. public class Cat extends Animal {
  4. private String catName;
  5. public String getCatName() {
  6. return catName;
  7. }
  8. public void setCatName(String catName) {
  9. this.catName = catName;
  10. }
  11. }

Dog.java

  1. @Entity
  2. @DiscriminatorValue(value="dog")
  3. public class Dog extends Animal{
  4. private String dogName;
  5. public String getDogName() {
  6. return dogName;
  7. }
  8. public void setDogName(String dogName) {
  9. this.dogName = dogName;
  10. }
  11. }

TestJunit.java

  1. @Test
  2. public void testAnimal(){
  3. Animal t = new Animal();
  4. t.setName("animal");
  5. session.saveOrUpdate(t);
  6. }
  7. @Test
  8. public void testCat(){
  9. Cat t = new Cat();
  10. t.setName("cat");
  11. t.setCatName("cat");
  12. session.saveOrUpdate(t);
  13. }
  14. @Test
  15. public void testDog(){
  16. Dog t = new Dog();
  17. t.setName("dog");
  18. t.setDogName("dog");
  19. session.saveOrUpdate(t);
  20. }

对应生成的数据表是这样的 
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

  1. @Entity
  2. @Inheritance(strategy=InheritanceType.JOINED)
  3. public class Animal {
  4. private int id;
  5. private String name;
  6. @Id
  7. @GeneratedValue
  8. public int getId() {
  9. return id;
  10. }
  11. public void setId(int id) {
  12. this.id = id;
  13. }
  14. public String getName() {
  15. return name;
  16. }
  17. public void setName(String name) {
  18. this.name = name;
  19. }
  20. }

Cat.java

  1. @Entity
  2. @PrimaryKeyJoinColumn(name="catId")
  3. public class Cat extends Animal {
  4. private String catName;
  5. public String getCatName() {
  6. return catName;
  7. }
  8. public void setCatName(String catName) {
  9. this.catName = catName;
  10. }
  11. }

Dog.java

  1. @Entity
  2. @PrimaryKeyJoinColumn(name="dogId")
  3. public class Dog extends Animal{
  4. private String dogName;
  5. public String getDogName() {
  6. return dogName;
  7. }
  8. public void setDogName(String dogName) {
  9. this.dogName = dogName;
  10. }
  11. }

TestJunit.java

  1. @Test
  2. public void testAnimal(){
  3. Animal t = new Animal();
  4. t.setName("animal");
  5. session.saveOrUpdate(t);
  6. }
  7. @Test
  8. public void testCat(){
  9. Cat t = new Cat();
  10. t.setName("cat");
  11. t.setCatName("cat");
  12. session.saveOrUpdate(t);
  13. }
  14. @Test
  15. public void testDog(){
  16. Dog t = new Dog();
  17. t.setName("dog");
  18. t.setDogName("dog");
  19. session.saveOrUpdate(t);
  20. }

对应生成的数据表是这样的 
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

  1. @Entity
  2. @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
  3. public class Animal {
  4. private int id;
  5. private String name;
  6. @Id
  7. @GeneratedValue(strategy=GenerationType.TABLE)
  8. public int getId() {
  9. return id;
  10. }
  11. public void setId(int id) {
  12. this.id = id;
  13. }
  14. public String getName() {
  15. return name;
  16. }
  17. public void setName(String name) {
  18. this.name = name;
  19. }
  20. }

Cat.java

  1. @Entity
  2. @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
  3. public class Cat extends Animal {
  4. private String catName;
  5. public String getCatName() {
  6. return catName;
  7. }
  8. public void setCatName(String catName) {
  9. this.catName = catName;
  10. }
  11. }

Dog.java

  1. @Entity
  2. @Inheritance(strategy=InheritanceType.TABLE_PER_CLASS)
  3. public class Dog extends Animal{
  4. private String dogName;
  5. public String getDogName() {
  6. return dogName;
  7. }
  8. public void setDogName(String dogName) {
  9. this.dogName = dogName;
  10. }
  11. }

TestJunit.java

  1. @Test
  2. public void testAnimal(){
  3. Animal t = new Animal();
  4. t.setName("animal");
  5. session.saveOrUpdate(t);
  6. }
  7. @Test
  8. public void testCat(){
  9. Cat t = new Cat();
  10. t.setName("cat");
  11. t.setCatName("cat");
  12. session.saveOrUpdate(t);
  13. }
  14. @Test
  15. public void testDog(){
  16. Dog t = new Dog();
  17. t.setName("dog");
  18. t.setDogName("dog");
  19. session.saveOrUpdate(t);
  20. }

对应生成的数据表是这样的 
table---animal

id name
1 animal

table---cat

id name catName
2 cat cat

table---dog

id name dogName
3 dog dog

转Hibernate继承的更多相关文章

  1. hibernate继承(转)

    http://justsee.iteye.com/blog/1070588 一.继承关系_整个继承树映射到一张表 对象模型(Java类结构) 一个类继承体系一张表(subclass)(表结构) Emp ...

  2. 【JavaEE】Hibernate继承映射,不用多态查询只查父表的方法

    几个月前,我在博问里面发了一个问题:http://q.cnblogs.com/q/64900/,但是一直没有找到好的答案,关闭问题以后才自己解决了,在这里分享一下. 首先我重复一下场景,博问里面举的动 ...

  3. SSH开发实践part3:hibernate继承映射

    0 大家好.上次讲了关于hibernate中双向1-N的映射配置,可以参考:http://www.cnblogs.com/souvenir/p/3784510.html 实际项目中,对象间的关系比较复 ...

  4. Hibernate继承映射

    在面向对象的程序领域中,类与类之间是有继承关系的,例如Java世界中只需要extends关键字就可以确定这两个类的父子关系,但是在关系数据库的世界中,表与表之间没有任何关键字可以明确指明这两张表的父子 ...

  5. web进修之—Hibernate 继承映射(5)

    先看三个类的继承关系,Payment是父类,CashPayment和CreditCardPayment是Payment的子类:   view plaincopy to clipboardprint p ...

  6. Hibernate继承类的实现

    版权声明:本文为博主原创文章,如需转载请标注转载地址. 博客地址:http://www.cnblogs.com/caoyc/p/5603724.html  对于继承关系类的映射.比如在论坛中文章(Ar ...

  7. hibernate 继承映射关系( SINGLE_TABLE)

    三种继承映射关系.   1,SINGLE_TABLE   person student  teacher 在一个表中,student和teacher继承自person,通过一个Discriminato ...

  8. Hibernate 继承映射可能会遇到的错误

    问题: 我们在配置hibernate的时候,默认是会配置下面的两个属性的 <property name="hibernate.default_catalog">hibe ...

  9. Hibernate继承注解

    hibernate应用中,继承的用途或目的主要有两点: 组件化:故明思义,把重复性的代码抽取成组件,以便重用和维护.hibernate应用中,一些重复的字段,重复的映射配置,就需要抽取成组件. 多态性 ...

随机推荐

  1. SQL*PLUS命令的使用大全

    Oracle的sql*plus是与oracle进行交互的客户端工具.在sql*plus中,可以运行sql*plus命令与sql*plus语句. 我们通常所说的DML.DDL.DCL语句都是sql*pl ...

  2. Sybase to Oracle Golden Gate

    Sybase 安装Golden Gate: 下载,然后create subdirs.并且在两端配置好mgr,设置好端口7809 创建golden gate用户ogguser,并且给它授权sa和repl ...

  3. vue中slot的用法案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. poj1050查找最大子矩阵和

    题目: To the Max   Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 48507   Accepted: 2566 ...

  5. STL中的迭代器的使用

    package com.text; import java.lang.reflect.Field;import java.util.ArrayList;import java.util.Iterato ...

  6. 《Exception》第八次团队作业:Alpha冲刺(第二天)

    一.项目基本介绍 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 Exception 作业学习目标 1.掌握软件测试基础技术.2.学习迭代式增量软 ...

  7. linux下的查找命令

    whereis <程序名称> 查找软件的安装路径 -b 只查找二进制文件 -m 只查找帮助文件 -s 只查找源代码 -u 排除指定类型文件 -f 只显示文件名 -B <目录> ...

  8. 线性回归(regression)

    简介 回归分析只涉及到两个变量的,称一元回归分析.一元回归的主要任务是从两个相关变量中的一个变量去估计另一个变量,被估计的变量,称因变量,可设为Y:估计出的变量,称自变量,设为X. 回归分析就是要找出 ...

  9. HDU 2155 Matrix

    Matrix Time Limit: 3000ms Memory Limit: 65536KB This problem will be judged on PKU. Original ID: 215 ...

  10. Ubuntu 常用快捷键

    本系列文章由 @YhL_Leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/50285313 1 桌面 快捷键 作用 ...