Spring Data JPA 之 一对一,一对多,多对多 关系映射详细笔记

前言最近在用Spring Data Jpa ,发现好多东西都是知道个大概,但不知其细节,所以细节地方配置的错了,就会导致很多业务场景SQL报错。特做此笔记,以防以后跳同样的坑。一、@OneToOne关系映射JPA使用@OneToOne来标注一对一的关系。实体 People :用户。实体 Address:家庭住址。People 和 Address 是一对一的关系。这里用两种方式描述JPA的一对一关系:一种是通过外键的方式(一个实体通过外键关联到另一个实体的主键);另外一种是通过一张关联表来保
摘要由CSDN通过智能技术生成

前言

最近在用Spring Data Jpa ,发现好多东西都是知道个大概,但不知其细节,所以细节地方配置的错了,就会导致很多业务场景SQL报错。特做此笔记,以防以后跳同样的坑。

一、@OneToOne关系映射

JPA使用@OneToOne来标注一对一的关系。

实体 People :用户。
实体 Address:家庭住址。
People 和 Address 是一对一的关系。
这里用两种方式描述JPA的一对一关系:
一种是通过外键的方式(一个实体通过外键关联到另一个实体的主键);
另外一种是通过一张关联表来保存两个实体一对一的关系。

1、通过外键的方式

people 表(id,name,sex,birthday,address_id)
address 表(id,phone,zipcode,address)

People.Java

@Entity
@Data
public class People {

   @Id
   @GeneratedValue(strategy = GenerationType.IDENTITY)
   @Column(name = "id", nullable = false)
   private Long id;//id

   @Column(name = "name", nullable = true, length = 20)
   private String name;//姓名

   @Column(name = "sex", nullable = true, length = 1)
   private String sex;//性别

   @Column(name = "birthday", nullable = true)
   private Timestamp birthday;//出生日期

   @OneToOne(cascade=CascadeType.ALL)//People是关系的维护端,当删除 people,会级联删除 address
   @JoinColumn(name = "address_id", referencedColumnName = "id")//people中的address_id字段参考address表中的id字段
   private Address address;//地址

}

关联的实体的主键一般是用来做外键的。但如果此时不想主键作为外键,则需要设置referencedColumnName属性。当然这里关联实体(Address)的主键 id 是用来做主键,所以这里的 referencedColumnName = “id” 实际可以省略。

Address.java

@Entity
@Data
public class Address {
 
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id", nullable = false)
    private Long id;//id
 
    @Column(name = "phone", nullable = t
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值