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

SpringDataJPA笔记(15)--Inheritance注解详解之JOINED

作者头像
yingzi_code
发布2020-04-22 10:41:40
6850
发布2020-04-22 10:41:40
举报

SpringDataJPA笔记(15)–Inheritance注解详解之JOINED

在JPA中使用映射注解Inheritance,有一种策略是JOINED

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

还是简单写个demo测试一下

先写三个实体类

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

    @Id
    private Long id;

    @Column(name = "joined_name")
    private String joinedName;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_joined_one_tb")
public class InheritanceJoinedOneEntity extends InheritanceJoinedEntity {

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "joined_one")
    private String joinedOne;
}
代码语言:javascript
复制
@Data
@Entity
@EqualsAndHashCode(callSuper = true)
@Table(name = "inheritance_joined_two_tb")
public class InheritanceJoinedTwoEntity extends InheritanceJoinedEntity {

    private static final long serialVersionUID = 9042160117012026124L;

    @Column(name = "joined_two")
    private String joinedTwo;
}

然后是三个repository接口类

代码语言:javascript
复制
public interface InheritanceJoinedRepository extends JpaRepository<InheritanceJoinedEntity, Long>, JpaSpecificationExecutor<InheritanceJoinedEntity>, Serializable {
}
代码语言:javascript
复制
public interface InheritanceJoinedOneRepository extends JpaRepository<InheritanceJoinedOneEntity, Long>, JpaSpecificationExecutor<InheritanceJoinedOneEntity>, Serializable {
}
代码语言:javascript
复制
public interface InheritanceJoinedTwoRepository extends JpaRepository<InheritanceJoinedTwoEntity, Long>, JpaSpecificationExecutor<InheritanceJoinedTwoEntity>, Serializable {
}

然后写controller类用于测试

代码语言:javascript
复制
@Autowired
    private InheritanceJoinedRepository inheritanceJoinedRepository;

    @Autowired
    private InheritanceJoinedOneRepository inheritanceJoinedOneRepository;

    @Autowired
    private InheritanceJoinedTwoRepository inheritanceJoinedTwoRepository;

    @PostMapping("/single")
    public InheritanceJoinedEntity single(@RequestBody InheritanceJoinedEntity inheritanceJoinedEntity) {
        return inheritanceJoinedRepository.save(inheritanceJoinedEntity);
    }

    @PostMapping("/joined/one")
    public InheritanceJoinedOneEntity joined(@RequestBody InheritanceJoinedOneEntity inheritanceJoinedEntity) {
        return inheritanceJoinedOneRepository.save(inheritanceJoinedEntity);
    }

    @PostMapping("/joined/two")
    public InheritanceJoinedTwoEntity joined(@RequestBody InheritanceJoinedTwoEntity inheritanceJoinedEntity) {
        return inheritanceJoinedTwoRepository.save(inheritanceJoinedEntity);
    }

    @GetMapping("/joined")
    public List<InheritanceJoinedEntity> joined() {
        return inheritanceJoinedRepository.findAll();
    }

    @GetMapping("/joined/one")
    public List<InheritanceJoinedOneEntity> joinedOne() {
        return inheritanceJoinedOneRepository.findAll();
    }

    @GetMapping("/joined/two")
    public List<InheritanceJoinedTwoEntity> joinedTwo() {
        return inheritanceJoinedTwoRepository.findAll();
    }

启动程序,查看数据库,有三张表

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

分别通过三个接口写入数据,再查看数据库数据

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

通过接口查询数据的结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

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