gpt4 book ai didi

java - 在 hibernate 中有效地从数据库加载集合的集合

转载 作者:行者123 更新时间:2023-11-30 06:49:43 25 4
gpt4 key购买 nike

我有一个带有 hibernate 的 Web 应用程序,它可以管理多种语言的数据。目前,基本上每个请求都会在语言翻译上生成大量的选择语句。模型大致如下:

Data <1-1> Placeholder <1-many> languageTranslation <many-1> language

如果我查询所有/许多数据对象,我会看到很多单选,它们为占位符选择一种语言翻译。我最想生成的 SQL:

SELECT * FROM data join placeholder join languagetranslation 
WHERE data.placeholder_id = placeholder.id
AND languagetranslation.placeholder_id = placeholder.id
AND languagetranslation.language_id = ?

这样我就可以在一次调用中获得带有占位符和翻译的所有数据。 languagetranslations 具有 language_id 和 placeholder_id 的复合主键。

我没有 HBM 文件,一切都是通过注释管理的。模型代码(仅显示相关部分):

@Entity
public class Data {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@OneToOne(fetch = FetchType.EAGER, cascade = CascadeType.ALL, optional = false)
@Fetch(FetchMode.JOIN)
private Placeholder content;
}

public class Placeholder {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@OneToMany(mappedBy = "primaryKey.placeholder", cascade = CascadeType.ALL, fetch = FetchType.EAGER, orphanRemoval = true)
@Fetch(FetchMode.JOIN)
private Set<LanguageTranslation> languageTranslations = new HashSet<>();
}

public class LanguageTranslation {

@EmbeddedId
private LanguageTranslationPK primaryKey = new LanguageTranslationPK();

@Type(type = "org.hibernate.type.StringClobType")
private String text;

}

@Embeddable
public class LanguageTranslationPK {

@ManyToOne(fetch = FetchType.EAGER)
@Fetch(FetchMode.JOIN)
private TextPlaceholder textPlaceholder;

@ManyToOne(fetch = FetchType.EAGER)
@Fetch(FetchMode.JOIN)
private Language language;
}

public class Language {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
}

我尝试了 FetchType 和 FetchMode,但无法生成我想要的行为,它总是对单一语言翻译进行单一选择。

我还尝试了多种查询方式:基于条件、HQL 和原始 SQL。我当前的原始 SQL 查询如下:

String sql_query = "select data.*, lt.* from Data as data join languagetranslation as lt on data.content_id = lt.textplaceholder_id";
Query q = getSession().createSQLQuery(sql_query).addEntity("data", Data.class).addJoin("data.content_id", "data.title").addJoin("lt", "data.content.languageTranslations").setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
return q.list();

我在这里做错了什么吗?我如何说服 hibernate 在一次数据库调用中获取所有实体?或者还有其他一些方法可以提高我的情况的性能(例如批量选择)?

最佳答案

您可以创建代理 pojo,其中包含所有实体变量以及 getter、setter 和构造函数。然后在 hibernate 查询中初始化此构造函数,以便您从数据库中获取所有需要的数据。

import com.proxy;
class userProxy{
private string name;
private string password;
private string address;
private int pincode;
private byte[] profilePic;
private int age;

public userProxy(string name,string password){
this.name = name;
this.password = password;
}

//Getter and setter of all variable...
}

然后使用这个构造函数来进行 Hibernate 查询,如

select new com.proxy.userProxy(user.name,user.password) from usertable

关于java - 在 hibernate 中有效地从数据库加载集合的集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43065694/

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