//@Inheritance(strategy = InheritanceType.SINGLE_TABLE)//继承
共一张表 存在继承关系的多个实体 的数据存在一张表中
//@Inheritance(strategy = InheritanceType.JOINED)//关系表
关系表 生成多张表 相互之间存在关联关
保存数据的时候 数据会碎片化 这个表存一个 另外再存一,
如继承一个主表,里面有一个主键,保存数据的时候,会把所有的主键生成一个表
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)//各一张表 重点
product是子类
ShopCar是子类
BaseBean是父类
如:以
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)为例
package com.oracle.bean7; import lombok.Data; import org.hibernate.annotations.GenericGenerator; import javax.persistence.*; @Entity @Data //@Inheritance(strategy = InheritanceType.SINGLE_TABLE)//继承 @Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)//各一张表 //@Inheritance(strategy = InheritanceType.JOINED)//关系表 //@DiscriminatorColumn(name="parent") public abstract class BaseBean {//抽象的类不可以被实例化 @Id @GeneratedValue(generator = "uuid") @GenericGenerator(name = "uuid",strategy = "uuid") private String pk; private String modifiedtime; private String creator; private String modifier; private String creationtime; }
package com.oracle.bean7; import lombok.Data; import org.hibernate.annotations.GenericGenerator; import javax.persistence.*; import java.util.List; @Data @Entity @Table(name="TProduct") //@DiscriminatorColumn(name="Product") public class Product extends BaseBean{ private String pname; }
package com.oracle.bean7; import lombok.Data; import org.hibernate.annotations.GenericGenerator; import javax.persistence.*; import java.util.List; @Data @Entity @Table(name="TShopCar") //@DiscriminatorColumn(name="ShopCar") public class ShopCar extends BaseBean{ // private List<Product> products; private String carname; }
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <property name="connection.url">jdbc:oracle:thin:@10.10.44.161:1521:ORCL</property> <property name="connection.driver_class">oracle.jdbc.OracleDriver</property> <property name="hbm2ddl.auto">update</property> <property name="show_sql">true</property> <property name="format_sql">true</property> <property name="connection.username">TANGBAO</property> <property name="connection.password">123456</property> <mapping class="com.oracle.bean7.Product"/> <mapping class="com.oracle.bean7.ShopCar"/> <mapping class="com.oracle.bean7.BaseBean"/> </session-factory> </hibernate-configuration>
子类会继承父类所有的属性