春季启动双向关系或多个查询

时间:2018-08-04 02:40:00

标签: spring spring-boot jpa spring-data-jpa

我正在使用Spring Boot Web服务,并且我想知道操纵数据之间实体之间关系的最佳方法。
第一种方法是使用如下所示的双向关系:
标题实体:

@Entity
public class Title {
    private Integer id;
    private String name;
    private List<TitleCelebrity> titleCelebrities;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    @Basic
    @Column(name = "name")
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @OneToMany(mappedBy = "title", cascade = CascadeType.ALL)
    public List<TitleCelebrity> getTitleCelebrities() {
        return titleCelebrities;
    }

    public void setTitleCelebrities(List<TitleCelebrity> titleCelebrities) {
        this.titleCelebrities = titleCelebrities;
    }
}

TitleCelebrity实体:

@Entity
@Table(name = "title_celebrity")
public class TitleCelebrity {
    private Integer id;
    private String type;
    private Title title;

    @Id
    @Column(name = "id")
    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    @Basic
    @Column(name = "type")
    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    @ManyToOne(cascade = CascadeType.ALL)
    @JoinColumn(name = "title_id")
    @JsonIgnore
    public Title getTitle() {
        return title;
    }

    public void setTitle(Title title) {
        this.title = title;
    }
}

因此,每次我请求获得标题时,我都会获得带有TitleCelebrity列表的Title,这就是我想要的。
现在另一种方法是不使用双向关系,而是进行两次查询,第一种是获取标题,然后根据该标题ID进行第二次查询以获取TitleCelebrity。
我更喜欢第二种方法,但这是最好的方法吗?

1 个答案:

答案 0 :(得分:1)

为什么选择更多的资源需求选项?如果您选择后者,则至少要使用联接。执行两个查询而不是让数据库一次处理所有查询都是不必要的浪费资源。

此外,让您的ORM(休眠)处理此类基本查询。真的没有理由自己写出查询。