인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

신동훈님의 프로필 이미지
신동훈

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

페치 조인 2 - 한계

강사님의 책에 나온 데이터 무결성이 깨지는 예제에 관하여 질문드립니다.

작성

·

189

0

안녕하세요 강사님. 항상 강의 잘 보고 있습니다.

강사님의 책 [자바 ORM 표준 JPA 프로그래밍]을 보고 궁금한 점이 생겨 질문드립니다.

381쪽에 "페치 조인 대상에는 별칭을 줄 수 없다"에 대한 설명들 중 다음과 같은 문장이 있습니다.

"하지만 별칭을 잘못 사용하면 연관된 데이터 수가 달라져서 데이터 무결성이 깨질 수 있으므로 조심해서 사용해야 한다."

여기서 언급하신 데이터 무결성이 깨지는 예시가 궁금하여 조금 찾아보았는데, 강사님이 남겨주신 여러 댓글들에 대한 답변을 보고 어느정도 감을 잡은 것 같긴 합니다만, 제대로 이해한 것인지 궁금하고, 또 그 이외에도 무결성이 깨지는 경우가 어떤 경우가 있는지 궁금하여 질문드립니다.

우선 제가 이해한 데이터 무결성이 깨지는 경우는 아래의 경우입니다.

"페치조인 사용 시 별칭을 준 후, where이나 on절에서 별칭을 사용하여 필터링 조건으로 사용하는 경우"

위의 경우가 데이터 무결성이 깨지는 이유는 다음과 같습니다.

페치조인 시 필터링을 거쳐서 데이터를 가져오게 되면 DB에 저장되어 있는 데이터의 개수와, DB에서 필터링하여 가져와 영속성 컨텍스트에 저장되는 데이터의 개수가 차이가 생겨, 데이터의 무결성이 깨지는 것입니다. 

제가 제대로 이해한 것이 맞을까요? 그리고 이 이외에도 데이터 무결성이 깨지는 예제가 혹시 더 있을까요?

 

[추가]

추가로 페치조인의 별칭을 준 대상을 on절에서 사용시에는 예외가 발생하고, where절에서 사용시에는 예외를 발생시키지 않는 이유가 무엇인지도 궁금합니다!

 

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 신동훈님

다음을 참고해주세요.

https://www.inflearn.com/questions/15876

일관성이 깨지는 케이스도 이 질문을 참고해서 다양하게 테스트해보시는 것을 추천합니다.

감사합니다.

신동훈님의 프로필 이미지
신동훈

작성한 질문수

질문하기