질문있습니다.
안녕하세요 영한님.
강의를 참고하여 프로젝트를 진행 했는데 문제가 발생해서 질문드립니다.
관리자(admin)가 item 테이블의 데이터 하나를 삭제하려고 할 때
해당 item을 주문한 orderItem이 존재하여 외래키 제약 조건 위반이 발생하여 삭제를 하지 못하는 경우,(제가 의도한 설계는 아닙니다)
어떤 식으로 해결 해나가야 할지 감이 잘 잡히지 않네요.
JPA에 외래키 제약 조건이 발생하더라도 강제로 삭제를 진행하는 옵션이 있다면 해당 옵션을 걸어줘야 하는지, 아니면 애초에 설계를 orderItem이 있다면 해당 item은 삭제가 안되게 설계를 해야하는건지
영한님이라면 어떻게 해결하실지 궁금합니다..ㅠㅠ
답변 1
1
안녕하세요. OMG님 좋은 질문입니다^^
설계의 의도상 외래 키 제약조건을 걸어두었다면, 이 경우 오류가 발생하는 것이 맞습니다.
(외래 키를 말하는 것이 아닙니다. 외래 키 제약 조건을 말하는 것입니다.)
만약 이 상황에서 order를 삭제하면, order가 없는 orderItem들은 향후 서비스에 큰 문제가 될 수 있습니다.
예를 들어서, 통계를 내야 하는데, order는 없지만 orderItem들만 있는 경우는 어떻게 처리할지 등등 수많은 정책들이 일관성이 없어지기 때문에 서비스를 유지보수하기 어려워집니다.
그래서 이런 경우 order를 삭제하기 전에 먼저 연관된 orderItem을 삭제하고, 그 다음에 order를 삭제해야 합니다.
그런데 만약 비즈니스 의사결정이 orderItem과 무관하게 order를 그냥 삭제해도 된다고 결정했다면, 외래키 제약 조건을 제거하면 됩니다.
참고로 JPA는 외래키 제약조건과 크게 관계가 없습니다. JPA가 테이블은 자동으로 만들어줄 때 기본으로 외래키 제약 조건을 추가하지만, 실제 DB 테이블을 만들 때 해당 외래키 제약조건을 넣거나 빼는 것은 DDL을 생성할 때 개발자와 DBA가 결정하면 됩니다.
추가로 데이터가 매우 많은 경우 성능과 유지관리 때문에, 비즈니스 요구사항이 외래 키 제약조건이 필요해도 어쩔 수 없이 포기하는 경우도 있습니다.
도움이 되셨길 바래요^^
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
27
1
sdk 설정 오류
0
64
2
오탈자 - @Transactional
0
62
1
src/test/resources 테스트 경로 문제
0
55
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
70
1
MemberRepositoryTest 실행오류
0
89
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
195
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
153
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
56
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
79
1
기본 생성자
0
66
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
106
1
멤버서비스테스트 부분에서 막힙니다.
0
173
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
123
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
128
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
121
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
63
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
81
2
Repository에서 EntityManager 주입 방식 차이
0
97
1
롬복과 사용자 정의 setter 메서드
0
77
1
주문 목록 조회 fetch join 질문드립니다
0
90
1
dirty checking 질문드립니다.
0
86
1





