gpt4 book ai didi

Hibernate FetchMode SELECT 与 JOIN

转载 作者:行者123 更新时间:2023-12-01 13:46:59 26 4
gpt4 key购买 nike

我有以下类(class):

   @Entity
public class TestContentElementResponse
{

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
protected Long id;



@OneToMany(mappedBy = "testContentElementResponse", cascade = CascadeType.ALL, orphanRemoval = false)
private Set<ResponseAttribute> associatedResponseAttributes = new HashSet<ResponseAttribute>();


@ManyToOne
@JoinColumn(name = "userfulltestId", referencedColumnName = "id", nullable = false)
private UserFullTest userFullTest;

@ManyToOne
@JoinColumn(name = "testContentElementId", referencedColumnName = "id", nullable = false)
private TestContentElement testContentElement;



@OneToOne(cascade = CascadeType.ALL)
private TestContentElementScore testContentElementScore;

@ManyToOne
@JoinColumn(name = "userId", referencedColumnName = "id", nullable = false)
private User user;

TestContentElementResponse.class 表示测试中的一个用户响应。一次测试可以包含 30 个问题,因此每个用户有 30 个回答。

现在我想为一个用户调用所有 TestContentElementResponse(公共(public) ID 是 UserFullTestId)并为每个 TestContentElementResponse 调用所有 ResponseAttributes。

我可以使用条件查询来执行此操作,但我不确定是使用 SELECT 还是 JOIN FetchMode。我确实知道 JOIN 将对数据库进行一次大调用,而 SELECT 将进行多次快速调用。但是,我不知道哪些因素可以帮助我决定哪种方法是最佳的。

(当然,我会进行测试,但那只会回答哪种方法是最佳的,不会解释为什么)

帮助将不胜感激

最佳答案

这里有一个很好的讨论,有一些具体的例子:

http://www.mkyong.com/hibernate/hibernate-fetching-strategies-examples/

如果您使用“原始 SQL”(SQL 语句或存储过程)进行编码,答案通常是显而易见的:单个复杂的“选择/连接”查询几乎总是优于多个查询。

就 Hibernate 而言,答案是“加入”通常比选择更好。

建议:修改您的 spring.xml 以启用“show_sql”,并比较结果。

附言:

另外两个不错的链接:

关于Hibernate FetchMode SELECT 与 JOIN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35248385/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com