2012-04-23 2 views
2

더 빠른 검색 쿼리를 얻기 위해 OneToMany 및 ManyToOne 관계에 대한 최대 절전 모드를 설정하는 최적의 방법은 누구에게 알 수 있습니까? OneToMany (mappedBy = ...)를 사용하기 위해 기본 릴레이션을 그대로 두어야합니까? 아니면 최적의 결과를 내기 위해 다른 방법이 사용됩니다.최대 절전 모드에서 OneToMany ManyToOne 관계를 설정하는 최적의 방법

나는 엔티티 트리를 가지며 주어진 노드 아래의 모든 관계를 가능한 빨리로드하려고합니다.

답변

-2

개체 그래프의 검색 또는로드에 대해 이야기하고 있는지 여부는 알 수 없습니다.

개체 그래프를로드 할 때 성능이 향상됩니다.

1) 데이터베이스 테이블에 대한 인덱스.
2) 가져 오기 전략 조정. n + 1 선택을 피하십시오.
3) 2 차 캐싱

색인은 항상 당신을 도와야하며, 또한 상당히 중요합니다. 가져 오기 전략을 조정하면 도움이 될 것이며, 2 단계 캐싱이 도움이 될 것입니다. 두 번째 및 세 번째의 경우 최적의 경로를 결정하기 위해 일부 메트릭을 수집해야합니다.

당신은 당신이

가능한 한 빨리으로 주어진 노드 아래의 모든 관계를로드 할 말할 때.

너무 많은 데이터를 한 번에로드하지 않도록주의하십시오. 때때로 최적화 된 hql을 작성하여 사용자에게 표시 할 객체 그래프의 요약을로드 한 다음 사용자가 개별 항목을 선택하면 전체 객체를로드하는 것이 더 나을 때가 있습니다.

+0

음. 그 반대의 경우 : 비 n + 1 선택을 피해야합니다. 조인을 사용하면 캐시를 사용하지 않으므로 글을 읽는 것보다 자주 읽는 경우 성능이 크게 저하됩니다. 일반 규칙 : 일반적인 요구 사항이없는 경우 lazy = true 및 fetch = select를 사용하십시오. –

+0

당신은 "그 반대"를 의미합니까? – hvgotcodes

+0

n + 1 선택을 피하고 조인을 사용하는 것이 좋습니다. 반대의 경우는 일반적인 경우 조인을 피하고 2 차 레벨 캐시를 활용하기 위해 선택 또는 하위 선택을 사용해야 함을 의미합니다. –

관련 문제