我有一个项目正在使用 Spring Data 存储库来自动生成它的一些方法。一种这样的方法是接受几个参数并返回书籍列表。在存储库中,该方法如下所示:
List<Book> findBySellerFlagTrueAndPublishedState(PublishedState state);
但是,当我使用该方法时,似乎休眠是延迟加载书籍的属性,这些属性被注释为 FetchType.EAGER。此外,当我使用 JPA 的 Criteriabuilder 自己构建查询时,我也遇到了同样的问题。当我使用默认findOne(Long id)
方法时,这些属性会被急切地加载。
我正在使用 JPA 2.0,并且正在使用 Hibernate 作为实现。
这是我遇到此问题的关系之一的注释:
@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(name="BOOK_THEME",
joinColumns=@JoinColumn(name="BOOK_ID", referencedColumnName="BOOK_ID"),
inverseJoinColumns=@JoinColumn(name="THEME_ID", referencedColumnName="THEME_ID"))
@OrderColumn(name="THEME_SEQUENCE")
private List<Theme> themes;
getter 和 setter 只是标准的,它是单向的关系(在 中没有书Theme
)。
我认为这一定是我如何设置注释的问题。有谁知道我有什么问题?