我想经过一些研究,我能够回答我自己的问题。关键是 Hibernate 将 2LC 中的对象脱水,这将影响您是否需要显式缓存关联。
如果我遗漏了任何内容或有任何细节错误,请添加更多详细信息。
这是一个简化的类结构:
@Entity
@Cacheable
public class Tutor
{
@OneToMany(mappedBy="tutor")
private Set<Student> students;
}
@Entity
@Cacheable
public class Student
{
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="TUTOR_FK")
private Tutor tutor;
}
对于休眠
二级缓存 (2LC) 以脱水形式存储实体,例如:
{1=CacheEntry(Tutor)[1, Jack Daw]}
{1=CacheEntry(Student)[1, Jane Smith, 1]}
Student 数据中的最后一个 1 是辅导的外键。
因此,如果您有对 Student id 1 的引用并遵循对导师的引用,我们会得到缓存命中,因为外键在缓存中。不需要额外的选择。
但是,如果您采用另一种方式,在 Tutor 上调用 getStudents(),则 2LC 中没有外键,因此需要选择。(一旦选择完成,hibernate 就有了 ids 并且可以开始点击 2LC)。
为避免这种情况,您需要将旧的 org.hibernate.annotations.Cache 注释添加到 @OneToMany 关系。
对于 EclipseLink
我手头没有 EclipseLink 安装,因此无法对此进行测试,但我知道 EclipseLink 以原始对象图的形式存储 2LC 数据,因此上述内容不相关。根据 Chris 的回答,实体与其引用一起缓存,因此不需要进一步注释。