hibernate继承策略之单表映射

类与类之间的继承关系,hibernate提供了三种映射策略。

InheritanceType.SINGE_TABLE :单表继承(在数据库中用同一张表存储具有继承关系的实体对象,通过不同的类型来区分父类与子类之间的关系)

InheritanceType.JOINED: 连接子类策略(在数据库中表示为用外键关联)

InheritanceType.TABLE_PER_CLASS: (每个子类对应一张数据库表模型)

(该篇只针对单表继承策略)

首先建表模型:

CREATE TABLE PERSION (ID NUMBER(18),  NAME VARCHAR2(255),  SEX NUMBER(2),  TYPE NUMBER(2)  );

对应的实体模型:

父类:

package cn.com.httpclient;

import javax.persistence.DiscriminatorColumn;
import javax.persistence.DiscriminatorType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
/**
 * 孩子,这是人类
 * @author xiaomingtongxie
 *
 */
@Entity
@Table(name = "PERSION")
@SequenceGenerator(name = "S_PERSION", sequenceName = "S_PERSION", allocationSize = 1)
//类继承方式,单表继承
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
//辨别者列,用于区分对应的实体
@DiscriminatorColumn(name = "type" ,discriminatorType = DiscriminatorType.INTEGER)
public class YPersion {
	@Id
	@GeneratedValue(generator = "S_PERSION", strategy = GenerationType.SEQUENCE)
	private Long id;
	/** 名字 */
	private String name;
	/** 性别 */
	private Integer sex;

	// /**类型*/
	// private Byte type;
	public Long getId() {
		return id;
	}

	public void setId(Long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Integer getSex() {
		return sex;
	}

	public void setSex(Integer sex) {
		this.sex = sex;
	}

	// 人的类型
	/** 工人 */
	public static int TYPE_GR = 0;
	/** 好人 */
	public static int TYPE_GOOD = 1;
	/** 坏人 */
	public static int TYPE_BAD = 2;

}

子类:

package cn.com.httpclient;

import javax.persistence.DiscriminatorValue;
import javax.persistence.Entity;
import javax.persistence.Table;

/**
 * 人类的子类,好人
 * @author xiaomingtongxie
 *
 */
@Entity
@Table(name = "PERSION")
//辨别者列值,好人
@DiscriminatorValue("1")
public class YGoodPersion extends YPersion{

}

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏java系列博客

写了个简单的job

1183
来自专栏乐沙弥的世界

PL/SQL 嵌套记录与记录集合

    将多个逻辑上不相关列组合到一起形成了PL/SQL的记录类型,从而可以将记录类型作为一个整体对待来处理。而且PL/SQL记录类型可以进行 嵌套以及基于PL...

592
来自专栏Jackson0714

详解SQL集合运算

3388
来自专栏数据和云

深入剖析:认识Oracle 中的 NULL 值

杨廷琨,网名 yangtingkun 云和恩墨技术总监,Oracle ACE Director,ACOUG 核心专家 经常看到很多人提出和NULL有关的问题。N...

2645
来自专栏数据和云

MySQL的前缀索引及Oracle的类似实现

MySQL有一个很有意思的索引类型,叫做前缀索引,它可以给某个文本字段的前面部分单独做索引,从而降低索引的大小。 其实,Oracle也有类似的实现,对于文本,它...

3535
来自专栏乐沙弥的世界

PL/SQL 集合的方法

    PL/SQL中提供了常用的三种集合联合数组、嵌套表、变长数组,而对于这几个集合类型中元素的操作,PL/SQL提供了相应的函数或过程来操 纵数组中的元素...

683
来自专栏数据之美

一千个不用 Null 的理由

港真,Null 貌似在哪里都是个头疼的问题,比如 Java 里让人头疼的 NullPointerException,为了避免猝不及防的空指针异常,千百年来程序猿...

2066
来自专栏杨建荣的学习笔记

pl/sql中的参数模式(r4笔记第54天)

在平时的工作中,可能通过pl/sql传入参数来做一些特定的操作,参数模式一般有In,out.in out这几种 比如dbms_sqltune下的PREPARE_...

3024
来自专栏Hongten

java开发_mysql中获取数据库表描述_源码下载

我们需要获取表:test_table表的描述信息,然后把描述信息插入到表:data_element_config中记录结果

1072
来自专栏菜鸟前端工程师

JavaScript学习笔记017-数值方法0Math0定时器

613

扫码关注云+社区