>Java >java지도 시간 >JPA 및 Hibernate에서 N 1 문제를 해결하는 방법은 무엇입니까?

JPA 및 Hibernate에서 N 1 문제를 해결하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-14 18:54:02765검색

How to Solve the N 1 Problem in JPA and Hibernate?

JPA 및 Hibernate의 N 1 문제 해결

N 1 문제는 관계형 데이터를 검색하기 위해 과도한 쿼리를 실행할 때 발생합니다. 예를 들어, Hibernate에서 초기 쿼리는 N개의 레코드를 가져오고 각각에 대해 연관된 레코드를 검색하려면 N개의 추가 쿼리가 필요합니다.

이 문제를 해결하려면 JOIN FETCH:

List<PostComment> comments = entityManager.createQuery(
    "select pc from PostComment pc join fetch pc.post p where pc.review = :review"
)
.setParameter("review", review)
.getResultList();

를 활용하세요. 이 JOIN FETCH는 N 1 쿼리를 제거하여 post 연결을 즉시 가져옵니다.

여러 하위 연결을 가져와야 하는 경우 초기 쿼리에서 하나의 컬렉션을 가져오고 후속 쿼리에서 다른 컬렉션을 가져옵니다.

자동 감지

통합 테스트는 N 1 문제를 감지하는 데 이상적입니다. db-util 프로젝트는 생성된 SQL 문의 예상 개수를 검증하기 위해 자동 JUnit 어설션을 제공합니다.

@Test
public void shouldNotHaveANPlusOneQuery() {
    // code to configure and execute db-util

    Assert.assertCountOfSqlStatementsPerformed(1);
}

위 내용은 JPA 및 Hibernate에서 N 1 문제를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.