인프런 영문 브랜드 로고
인프런 영문 브랜드 로고
채널톡 아이콘

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

감바스님의 프로필 이미지

작성한 질문수 84

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

영속성 전이(CASCADE)와 고아 객체

CascadeType.ALL, CascadeType.REMOVE 옵션에 대해 질문 있습니다.

해결된 질문

작성

·

146

·

수정됨

0

부모를 삭제 시에는 CascadeType.ALL과 CascadeType.REMOVE가 똑같이 동작한다고 이해해서 이 둘에 대해 동시에 질문 하겠습니다.

만약에 하나의 게시글이 있고 이 게시글에 달려있는 첨부파일들이 100개 라고 하겠습니다.

이때 CascadeType.ALL 옵션을 사용하면 게시글 삭제 시 100개의 첨부파일들도 삭제 된다고 이해를 했습니다.

  1. 궁굼한 부분은 게시글 삭제 시 게시글에 달린 100개의 첨부파일에 대해 delete 쿼리가 따로 따로 보내지는건지 아니면 jpa가 최적화 해서 한번에 보내는건지 궁금합니다.

  2. 만약에 1번 질문에서 Jpa가 알아서 최적화해서 delete 쿼리를 DB로 보낸다고 가정하겠습니다. 그러면 100개의 첨부파일에 대한 Id 값을 다 뽑아서 이 값들을 delete 쿼리의 where절의 in에 넣어서 삭제 쿼리를 보내는것 대신에 Jpa가 최적화 해서 delete 쿼리를 보내는 방식이 더 좋은지 궁금합니다.

답변 1

0

y2gcoder님의 프로필 이미지

안녕하세요. 감바스님, 공식 서포터즈 y2gcoder입니다.

 

다음 링크(클릭)을 참고해보시면 delete 쿼리가 각각 따로 날라가는 것을 보실 수 있습니다.

 

감사합니다.

감바스님의 프로필 이미지
감바스
질문자

delete 쿼리가 각각 따로 날라가게 되면 CascadeType.ALL 옵션 사용시 성능상의 문제가 있지 않나요?

게시글에 첨부파일이 몇백개가 달려 있는 경우 게시글 삭제 시 몇백개의 delete 쿼리가 발생해서 성능상 괜찮을까 라는 생각이 듭니다.

y2gcoder님의 프로필 이미지

그래서 말씀하신 이유 때문에라도 cascadeType.ALL을 도입할 때 신중하게 고려해봐야 한다고 생각합니다 🙂

첨부파일이 몇백 개나 있으면 말씀하신 것처럼 미리 첨부파일을 한꺼번에 삭제하는 쿼리를 수행 후에 게시글을 삭제하는 방식으로 구현하는 게 맞는 것 같습니다 🙂

이는 cascade를 했더라도 하실 수 있습니다!

감바스님의 프로필 이미지
감바스
질문자

답변 감사합니다!