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

미니형님의 프로필 이미지
미니형

작성한 질문수

실전! Querydsl

수정, 삭제 벌크 연산

@OneToMany 에서 Cascade 되어있는데 foreign key로 연결되어 있는 테이블 삭제가 안됩니다.

작성

·

394

·

수정됨

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
영상에서 12분 40초 부분에 bulkDelete와 관련된 내용입니다. 저는 일단 예제와는 조금 다르게 진행을 하였는데요. delete 하려는 User entity에는 OneToMany 관계로 되어있는 테이블이 하나 있습니다. 그래서 User entity에 Cascade All을 추가했는데 querydsl에서는 에러가 뜨면서 실행이 안되더라구요.

제가알기로는 cascade를 설정해주면 entity가 삭제될 때 관련된 foreign key를 삭제해주는걸로 알고 있는데 아무리 찾아봐도 답이 안보여서 이렇게 질문남깁니다.

답변 1

1

안녕하세요, 이석원 님. 공식 서포터즈 y2gcoder 입니다.

수정, 삭제 등의 벌크 연산은 영속성 컨텍스트를 사용하지 않고 바로 DB에 쿼리를 날리게 됩니다.

반면 영속성 전이(Cascade)는 말 그대로 엔티티의 영속화 상태를 전이하는 기술이기 때문에 영속성 컨텍스트를 이용합니다.
따라서 영속성 컨텍스트를 거치지 않고 바로 SQL을 수행하는 벌크 연산의 특성 때문에 cascade 효과를 받을 수 없습니다.


감사합니다.

미니형님의 프로필 이미지
미니형
질문자

감사합니다! 덕분에 왜 안되는지 이해했습니다ㅠㅠ

파이팅입니다!

미니형님의 프로필 이미지
미니형

작성한 질문수

질문하기