一尘不染

Hibernate CollectionOfElements EAGER提取重复元素

hibernate

我有一个名为SynonymMapping的类,该类具有映射为CollectionOfElements的值的集合

@Entity(name = "synonymmapping")
public class SynonymMapping {

    @Id private String keyId;

    //@CollectionOfElements(fetch = FetchType.EAGER)
    @CollectionOfElements
    @JoinTable(name="synonymmappingvalues", joinColumns={@JoinColumn(name="keyId")})
    @Column(name="value", nullable=false)
    @Sort(type=SortType.NATURAL)
    private SortedSet<String> values;

    public SynonymMapping() {
        values = new TreeSet<String>();
    }

    public SynonymMapping(String key, SortedSet<String> values) {
        this();
        this.keyId = key;
        this.values = values;
    }

    public String getKeyId() {
        return keyId;
    }

    public Set<String> getValues() {
        return values;
    }
}

我有一个测试,其中我将两个SynonymMapping对象存储到数据库,然后要求数据库返回所有已保存的SynonymMapping对象,期望接收到我存储的两个对象。

当我将值的映射更改为热切时(如代码中注释行所示)并再次运行测试,我收到了四个匹配项。

我已经清除了两次运行之间的数据库,我可以复制在急切和懒惰之间交换此问题的方法。

我认为这与hibernate在下面创建的联接有关,但我无法在网上找到明确的答案。

谁能告诉我为什么急切地提取对象?

谢谢。


阅读 273

收藏
2020-06-20

共1个答案

一尘不染

在映射中强制执行紧急获取通常不是一个好主意-
最好在适当的查询中指定紧急连接(除非您100%确定在任何情况下您的对象在没有该集合的情况下都不会有意义/有效)正在填充)。

您得到重复项的原因是因为Hibernate在内部连接了根表和集合表。请注意,它们实际上是重复项,例如,对于2个具有3个集合元素的SynonymMappings,您将获得6个结果(2x3),每个SynonymMapping实体3个副本。因此,最简单的解决方法是将结果包装在Set中,从而确保它们是唯一的。

2020-06-20