문서의 선택한 두 판 사이의 차이를 보여줍니다.
양쪽 이전 판 이전 판 다음 판 | 이전 판 | ||
java:hibernate:gotchas [2017/11/30 22:17] kwon37xi [쿼리 로그를 남겨라] |
java:hibernate:gotchas [2023/07/03 14:54] (현재) kwon37xi [to-many 관계에 대해서 fetch join은 안하는게 낫다] |
||
---|---|---|---|
줄 1: | 줄 1: | ||
- | ====== Hibernate/ | + | ====== Hibernate/ |
하이버네이트/ | 하이버네이트/ | ||
줄 12: | 줄 12: | ||
따라서 ID를 equals/ | 따라서 ID를 equals/ | ||
+ | ===== to-many 관계에 대해서 fetch join은 안하는게 낫다 ===== | ||
+ | * to-many 관계에 대해서 fetch join 을 하면 부모측이 자식측(many)의 갯수만큼 중복으로 결과 갯수가 늘어난다. | ||
+ | * 이를 해결하려면 '' | ||
+ | * to-many 관계에 대해서 '' | ||
+ | * 때문에 하이버네이트는 SQL에 limit을 걸리 않고 limit 없이 전체 데이터를 조회한 뒤에 메모리에서 parent 데이터를 원하는 limit 갯수만큼 끊어서 반환한다. | ||
+ | * 이는 엄청난 성능저하로 이어진다. | ||
+ | * 결과적으로 특별한 이유가 없다면 **to-many 관계에 대해서는 fetch join을 하지 말고 항상 '' | ||
+ | * [[java: | ||
+ | * '' | ||
+ | * [[java: | ||
===== One-To-One 과 Many-To-One 관계를 조심하라 ===== | ===== One-To-One 과 Many-To-One 관계를 조심하라 ===== | ||
One-To-One과 Many-To-One 관계에서 One 측은 '' | One-To-One과 Many-To-One 관계에서 One 측은 '' | ||
줄 93: | 줄 103: | ||
* [[https:// | * [[https:// | ||
+ | ===== SQL / JPQL / HQL Keyword " | ||
+ | * [[https:// | ||
+ | * [[https:// | ||
+ | * Entity 의 package name 에 '' | ||
+ | * **패키지 이름에서 '' | ||
+ | * [[https:// | ||
+ | ===== null id in entry ===== | ||
+ | > HHH000099: an assertion failure occurred (this may indicate a bug in Hibernate, but is more likely due to unsafe use of the session): org.hibernate.AssertionFailure: | ||
+ | |||
+ | * [[https:// | ||
+ | * 핵심은 **" | ||
+ | * 하나의 트랜잭션에서 | ||
+ | * 쓰기 작업시 에러가 발생해서 '' | ||
+ | * 혹은, entity 삭제가 아니 직접 쿼리로 엔티티를 삭제하거나 한 상황에서 | ||
+ | * '' | ||
+ | * 나중에 flush 가 일어날 때 잘못된 Entity 혹은 DB상에 존재하지도 않지만 기존에 존재했던 것처럼 표시된 Entity 때문에 오류가 발생하게 된다. | ||
+ | * 쓰기 작업과 그 후속 읽기 작업 트랜잭션을 분리해서 '' | ||
+ | * 혹은 직접 쿼리를 통한 삭제 작업의 경우에는 '' | ||
===== 참조 ===== | ===== 참조 ===== | ||
* [[http:// | * [[http:// | ||
* 기타 직접 겪은 것들을 정리한다. | * 기타 직접 겪은 것들을 정리한다. |