繁体   English   中英

在spring boot jpa中一次保存一个实体及其所有相关实体

[英]Save an entity and all its related entities in a single save in spring boot jpa

我正在使用Spring Boot,REST和JPA构建我的应用程序。 在应用程序中,有4个具有一对多关系的实体。

是否可以在一个保存操作中保存多个实体?

请帮忙!

Parent.java

@Entity
@Data
@NoArgsConstructor 
public class Parent implements Serializable {
    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private long id;
    private String name;

    @OneToMany(mappedBy = "parent", cascade = CascadeType.ALL)
    private List<ChildA> childA = new ArrayList<>();

    @OneToMany(mappedBy = "parent", cascade = CascadeType.ALL)
    private List<ChildB> childB = new ArrayList<>();

    @OneToMany(mappedBy = "parent", cascade = CascadeType.ALL)
    private List<ChildC> childC = new ArrayList<>();

    ... getter and setter ...

}

ChildA.java

@Entity
@Data
@NoArgsConstructor
public class ChildA{
    @Id
    @GeneratedValue(strategy= GenerationType.AUTO)
    private long id;

    @ManyToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
    @JoinColumn(name = "parentId")
    private Parent parent;

    private String name;

    public void setParent(Parent parent){
        this.parent = parent;
    }

    ... getter and setter ...
}

ChildB.javaChildC.javaChildA.java相似

Repository.java

@Repository
public interface repository extends JpaRepository<Parent, Long> {

}

我想保存这个json。

{
  "name": "parent-name",
  "childA": [
    {
      "name": "parent-childA"
    }
  ],
  "childB": [
    {
      "name": "parent-childB"
    }
  ],
  "childC": [
    {
      "name": "parent-childC"
    }
  ]
}

D B

Parent
id   |   name
5        parent-name

ChildA
id   |   parent-id  |  name
 1   |       5      |  parent-childA

ChildB
id   |   parent-id  |  name
 1   |       5      |  parent-childA

ChildC
id   |   parent-id  |  name
 1   |       5      |  parent-childA

我找到了答案。 谢谢回复。

@RestController
public class ParentController {
    @Autowired
    private ParentRepository parentRepository;

    @PutMapping("")
    public void save(@RequestBody @Valid Parent parent) {
        parentRepository.save(parent);

    }

Parent.java添加@JsonManagedReference

@JsonManagedReference
@OneToMany(mappedBy = "parent", cascade = CascadeType.ALL)
private List<ChildA> childA = new ArrayList<>();

并将Child类ChildA.java,ChildB.java,ChildC.java添加@JsonBackReference

@JsonBackReference
@ManyToOne(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@JoinColumn(name = "parentId")
private Parent parent;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM