inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

실전 예제 3 - 다양한 연관관계 매핑

부모 자식관계에서 부모 삭제시 Set Null방법에 대해궁금합니다.

해결된 질문

3772

donald

작성한 질문수 2

8

안녕하세요~ 

부모테이블과 자식테이블간의 관계를  자식테이블에서 ManyToOne으로 단반향으로만 설정하고

부모의 PK 값이 Null이 허용(FK가 NUll 허용) 되는 테이블일때

부모의 테이블 값을 삭제할 경우 자식테이블에서 참조하고있는 부모의값을 null로 변경하고싶습니다.

인터넷으로 검색해보니 해결책으론 부모테이블 삭제할때 참조하고있는 자식테이블을 조회하여 일일히 반복문을 통해 null을 처리하더라구요

이와같은 방법말고 부모의값이 delete될때 자식이 자동으로 null 처리되게 자동으로 맵핑하는방법이있을까요?

DB에선 직접 외래키 설정시  OnDelete, OnUpdate에 제약조건으로 cascade, set null 등을 하는것이 가능한데

위와같은 방법으로 자동 맵핑해줄 수 있을까요?

( 부서 테이블과 사원테이블이 있을때, 신입사원의 경우 부서테이블자체가 존재하지않기때문에 참조값없이 null값을 저장하고
부서이동간에 부서가 삭제되었을떄 해당 부서의 인원들을 null 처리 해주시 위함입니다.)

@ManyToOne
@OnDelete(action = OnDeleteAction.NO_ACTION)
@JoinColumn(name ="post_idx")
private Post post;
public enum OnDeleteAction {
/**
* Take no action. The default.
*/
NO_ACTION,
/**
* Use cascade delete capabilities of the database foreign-key.
*/
CASCADE
}

위와같이 OnDelete 어노테이션으론  NO_ACTION, CASCADE 밖에 존재하지않아서 질문드립니다.

java JPA

답변 1

11

김영한

안녕하세요. donald님

이 경우 OnDelete, OnUpdate같은 방법을 사용하는 것은 오히려 복잡해지고, 좋지 않은 방법입니다.

JPA는 객제지향 스타일로 개발 하는 것이 원칙입니다. 따라서 부모 엔티티를 삭제하기 전에 자식 엔티티를 찾고, 부모 엔티티와 연관관계를 null 처리 하는 것이 맞습니다.

만약 성능이 고민된다면, 배치 update JPQL(객체지향 쿼리 언어2 - 벌크 연산 참고)을 사용해서 한번에 해당 부모와 관련있는 모든 자식 엔티티의 부모 FK 값을 null로 변경하면 됩니다.

감사합니다.

실무 조언 관련 질문입니다.

0

41

1

H2데이터베이스 파일 생성

0

49

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

49

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

47

1

JPQL 메소드와 락

0

50

1

Delivery @OneToOne

0

57

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

87

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

87

2

연관관계 매핑 질문드립니다.

0

81

2

h2데이터베이스 실행오류

0

104

2

persistence.xml

0

102

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

89

1

Native Query와 MyBatis

0

63

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

82

1

임베디드 타입 예시 코드 관련 질문

0

112

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

90

3

인텔리제이 패키지 커서 단축키 질문

0

106

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

135

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

175

2