>데이터 베이스 >MySQL 튜토리얼 >Fetch를 사용하는 NHibernate QueryOver가 여러 데이터베이스 쿼리를 발생시키는 이유는 무엇이며 어떻게 최적화할 수 있습니까?

Fetch를 사용하는 NHibernate QueryOver가 여러 데이터베이스 쿼리를 발생시키는 이유는 무엇이며 어떻게 최적화할 수 있습니까?

DDD
DDD원래의
2025-01-04 12:04:35351검색

Why Does NHibernate QueryOver with Fetch Cause Multiple Database Queries, and How Can I Optimize It?

Fetch가 여러 쿼리 실행을 발생시키는 NHibernate QueryOver

Fetch 절을 사용하여 QueryOver를 실행하여 상위 엔터티와 해당 하위 컬렉션을 검색하면 종종 결과가 발생합니다. 과도한 데이터베이스 적중. 이 동작은 NHibernate가 하위 컬렉션의 각 행에 대해 별도의 쿼리를 실행하기 때문에 발생합니다.

이를 이해하려면 UserRole 엔터티와 UsersInRole 컬렉션이 있는 시나리오를 고려해 보세요. 첫 번째 쿼리는 UserRole 엔터티를 검색합니다.

SELECT ... FROM UserRoles
left outer join UsersInRoles on ...

검색된 각 UserRole에 대해 NHibernate는 별도의 쿼리를 실행하여 UsersInRole 컬렉션을 가져오고 다음 형식의 수많은 쿼리가 생성됩니다.

SELECT ... FROM UsersInRoles
left outer join UserRoles on ...
WHERE UserRoles.UserId=?

이 동작을 최적화하기 위해 NHibernate는 HasManyToMany에 BatchSize 속성을 설정할 수 있도록 허용합니다. 매핑:

HasManyToMany(x => x.UsersInRole)
  ...
  .BatchSize(25)

이 옵션을 지정하면 NHibernate는 하위 컬렉션을 일괄적으로 로드하여 데이터베이스 쿼리 수를 최대 1(배치 크기 / 페이지 크기)로 줄입니다. 이를 통해 과도한 데이터베이스 적중을 방지하면서 관련 데이터를 효율적으로 검색할 수 있습니다.

위 내용은 Fetch를 사용하는 NHibernate QueryOver가 여러 데이터베이스 쿼리를 발생시키는 이유는 무엇이며 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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