![](/img/trans.png)
[英]Save an entity and all its related entities in a single save in spring boot
[英]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.java和ChildC.java与ChildA.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.