hibernate中的InheritanceType.SINGLE_TABLE,InheritanceType.TABLE_PER_CLASS,InheritanceType.JOINED

//@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>

子类会继承父类所有的属性

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值