작성
·
189
0
안녕하세요 강사님. 항상 강의 잘 보고 있습니다.
강사님의 책 [자바 ORM 표준 JPA 프로그래밍]을 보고 궁금한 점이 생겨 질문드립니다.
381쪽에 "페치 조인 대상에는 별칭을 줄 수 없다"에 대한 설명들 중 다음과 같은 문장이 있습니다.
"하지만 별칭을 잘못 사용하면 연관된 데이터 수가 달라져서 데이터 무결성이 깨질 수 있으므로 조심해서 사용해야 한다."
여기서 언급하신 데이터 무결성이 깨지는 예시가 궁금하여 조금 찾아보았는데, 강사님이 남겨주신 여러 댓글들에 대한 답변을 보고 어느정도 감을 잡은 것 같긴 합니다만, 제대로 이해한 것인지 궁금하고, 또 그 이외에도 무결성이 깨지는 경우가 어떤 경우가 있는지 궁금하여 질문드립니다.
우선 제가 이해한 데이터 무결성이 깨지는 경우는 아래의 경우입니다.
"페치조인 사용 시 별칭을 준 후, where이나 on절에서 별칭을 사용하여 필터링 조건으로 사용하는 경우"
위의 경우가 데이터 무결성이 깨지는 이유는 다음과 같습니다.
페치조인 시 필터링을 거쳐서 데이터를 가져오게 되면 DB에 저장되어 있는 데이터의 개수와, DB에서 필터링하여 가져와 영속성 컨텍스트에 저장되는 데이터의 개수가 차이가 생겨, 데이터의 무결성이 깨지는 것입니다.
제가 제대로 이해한 것이 맞을까요? 그리고 이 이외에도 데이터 무결성이 깨지는 예제가 혹시 더 있을까요?
[추가]
추가로 페치조인의 별칭을 준 대상을 on절에서 사용시에는 예외가 발생하고, where절에서 사용시에는 예외를 발생시키지 않는 이유가 무엇인지도 궁금합니다!
답변 1
0
안녕하세요. 신동훈님
다음을 참고해주세요.
https://www.inflearn.com/questions/15876
일관성이 깨지는 케이스도 이 질문을 참고해서 다양하게 테스트해보시는 것을 추천합니다.
감사합니다.