将实体及其所有相关实体保存在spring boot jpa

时间:2017-11-17 07:14:20

标签: java jpa spring-boot

我使用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"
    }
  ]
}

DB

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

1 个答案:

答案 0 :(得分:2)

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

@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<>();

和儿童班 ChildA.java,ChildB.java,ChildC.java 添加@JsonBackReference

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