前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringDataJPA笔记(14)-Inheritance注解详解之SINGLE_TABLE

SpringDataJPA笔记(14)-Inheritance注解详解之SINGLE_TABLE

作者头像
yingzi_code
发布2020-04-22 10:44:05
2.2K0
发布2020-04-22 10:44:05
举报
文章被收录于专栏:生活不止眼前的代码

SpringDataJPA笔记(14)-Inheritance注解详解之SINGLE_TABLE

在JPA中使用映射注解Inheritance,有三种策略属性

SINGLE_TABLE – 将所有父类和子类集合在一张表

TABLE_PER_CLASS – 每个子类会生成一张单独的表,父类可以查询所有子类的表数据,参考上一篇笔记Union查询

JOINED – 每个类分别生成一张单独的表,但是每张表只有自己的属性,没有父类的属性,通过外键关联的形式使两张表关联起来

代码语言:javascript
复制
public enum InheritanceType { 

    /** A single table per class hierarchy. */
    SINGLE_TABLE, 

    /** A table per concrete entity class. */
    TABLE_PER_CLASS, 

    /** 
     * A strategy in which fields that are specific to a 
     * subclass are mapped to a separate table than the fields 
     * that are common to the parent class, and a join is 
     * performed to instantiate the subclass.
     */
    JOINED 
}

简单写个demo测试一下

分别新建三个实体类

代码语言:javascript
复制
@Data
@Table(name = "inheritance_single_tb")
@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class InheritanceSingleEntity implements Serializable {
    private static final long serialVersionUID = 8139674112977338603L;

    @Id
    private Long id;

    @Column(name = "single_name")
    private String singleName;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_single_one_tb")
public class InheritanceSingleOneEntity extends InheritanceSingleEntity{

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "single_one")
    private String singleOne;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_single_two_tb")
public class InheritanceSingleTwoEntity extends InheritanceSingleEntity {

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "single_two")
    private String singleTwo;
}

再新建三个repository接口类

代码语言:javascript
复制
public interface InheritanceSingleRepository extends JpaRepository<InheritanceSingleEntity, Long>, JpaSpecificationExecutor<InheritanceSingleEntity>, Serializable {
}
代码语言:javascript
复制
public interface InheritanceSingleOneRepository extends JpaRepository<InheritanceSingleOneEntity, Long>, JpaSpecificationExecutor<InheritanceSingleOneEntity>, Serializable {
}
代码语言:javascript
复制
public interface InheritanceSingleTwoRepository extends JpaRepository<InheritanceSingleTwoEntity, Long>, JpaSpecificationExecutor<InheritanceSingleTwoEntity>, Serializable {
}

新建一个controller类用于测试数据情况

代码语言:javascript
复制
@RestController
@RequestMapping("/chapter/inheritances")
public class ChapterInheritanceController {

    @Autowired
    private InheritanceSingleRepository inheritanceSingleRepository;

    @Autowired
    private InheritanceSingleOneRepository inheritanceSingleOneRepository;

    @Autowired
    private InheritanceSingleTwoRepository inheritanceSingleTwoRepository;

    @PostMapping("/single")
    public InheritanceSingleEntity single(@RequestBody InheritanceSingleEntity inheritanceSingleEntity){
        return inheritanceSingleRepository.save(inheritanceSingleEntity);
    }

    @PostMapping("/single/one")
    public InheritanceSingleOneEntity single(@RequestBody InheritanceSingleOneEntity inheritanceSingleEntity){
        return inheritanceSingleOneRepository.save(inheritanceSingleEntity);
    }

    @PostMapping("/single/two")
    public InheritanceSingleTwoEntity single(@RequestBody InheritanceSingleTwoEntity inheritanceSingleEntity){
        return inheritanceSingleTwoRepository.save(inheritanceSingleEntity);
    }

    @GetMapping("/single")
    public List<InheritanceSingleEntity> single(){
        return inheritanceSingleRepository.findAll();
    }

    @GetMapping("/single/one")
    public List<InheritanceSingleOneEntity> singleOne(){
        return inheritanceSingleOneRepository.findAll();
    }

    @GetMapping("/single/two")
    public List<InheritanceSingleTwoEntity> singleTwo(){
        return inheritanceSingleTwoRepository.findAll();
    }
}

此时查看数据库,看到生成了一张表

在这里插入图片描述
在这里插入图片描述

查看表结构,发现有三张表的字段同时存在

这里还有一个dtype的字段,这个是默认的区别的字段名,还可以用@DiscriminatorColumn加@DiscriminatorValue的注解来指定
在这里插入图片描述
在这里插入图片描述

在swagger页面分别通过三个接口创建三条数据,查看表数据

在这里插入图片描述
在这里插入图片描述

例如加上@DiscriminatorColumn加@DiscriminatorValue的注解

代码语言:javascript
复制
@Data
@Table(name = "inheritance_single_tb1")
@Entity
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name = "single_type", discriminatorType = DiscriminatorType.STRING)
@DiscriminatorValue(value = "base")
public class InheritanceSingleEntity implements Serializable {
    private static final long serialVersionUID = 8139674112977338603L;

    @Id
    private Long id;

    @Column(name = "single_name")
    private String singleName;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_single_one_tb")
@DiscriminatorValue(value = "one")
public class InheritanceSingleOneEntity extends InheritanceSingleEntity{

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "single_one")
    private String singleOne;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_single_two_tb")
@DiscriminatorValue(value = "two")
public class InheritanceSingleTwoEntity extends InheritanceSingleEntity {

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "single_two")
    private String singleTwo;
}

写入三条数据之后查看数据库

在这里插入图片描述
在这里插入图片描述

再通过查询接口查询数据

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

可以看到通过父类查询可以查询所有数据,而子类只能分别查询出子类的数据

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 这里还有一个dtype的字段,这个是默认的区别的字段名,还可以用@DiscriminatorColumn加@DiscriminatorValue的注解来指定
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档