有效解决 JPA 和 Hibernate 中的 N 1 问题
当初始查询检索 N 条记录时,就会出现 N 1 查询问题,并且后续查询会出现 N 1 查询问题。执行查询以获取这 N 条记录中每条记录的关联关系记录。在 Hibernate 中克服此问题需要采取全面的方法。
理解问题
当您在未初始化关联关系的情况下获取记录时,就会出现 N 1 查询问题。当您稍后尝试访问该关系时,Hibernate 会执行其他查询来获取所需的信息。这会导致执行 N 1 个查询,而不是单个查询。
解决问题
要在 Hibernate 中解决此问题,有效的解决方案包括使用 JOIN FETCH条款。通过将此子句附加到您的初始查询中,您可以急切地获取导致问题的关系:
List<PostComment> comments = entityManager.createQuery( "select pc from PostComment pc join fetch pc.post p where pc.review = :review", PostComment.class) .setParameter("review", review) .getResultList();
如果您需要获取多个子关联,建议在主查询中获取一个集合,然后其余的在单独的查询中。
自动检测
至无缝检测 N 1 查询问题,强烈建议将自动 JUnit 断言合并到集成测试中。 db-util 等工具提供了一个开源实用程序,用于验证生成的 SQL 语句的数量,确保您的代码不会在不知不觉中遭受此性能瓶颈。
以上是如何有效解决JPA和Hibernate中的N 1问题?的详细内容。更多信息请关注PHP中文网其他相关文章!