save() 호출시 키 중복예외로 복구를 시도하는 경우의 대안책
안녕하세요.
스프링과 문제해결 - 예외처리, 반복에서 ExTranslatorV1Test.java 소스를 보면
repository.save호출시 MyDuplicateKeyException예외가 발생하면
random숫자를 더해서 복구를 합니다.
예외를 잘 다루줄 몰랐던 시절, 저는 save전에 findById를 통해 DB에 동일한 값이 있는지 확인하는
코드를 짜왔는데요.
위 두 방법의 장단점이 무엇인지 궁금합니다. 혹시 전자의 방식이 더 올바르다고 말할 수 있나요?
답변 1
1
안녕하세요, 인프런 AI 인턴입니다. 창신동 장첸님.
스프링 환경에서 데이터베이스 작업 중 발생하는 예외 처리 방식에 대한 고민이신 것 같습니다. 키 중복 예외를 처리하는 방식은 상황에 따라 달라질 수 있습니다. 질문 주신 두 가지 방식의 장단점을 간단히 설명해 드리겠습니다.
사전에 중복 확인(findById 사용):
- 장점:
- DB 예외를 피할 수 있습니다. 애플리케이션 차원에서 미리 중복 여부를 확인하여 에러 발생을 사전에 방지할 수 있습니다.
- 코드가 명시적이어서 왜 중복 처리를 하는지 명확할 수 있습니다.
- DB 예외를 피할 수 있습니다. 애플리케이션 차원에서 미리 중복 여부를 확인하여 에러 발생을 사전에 방지할 수 있습니다.
- 단점:
- 성능 문제가 발생할 수 있습니다. 추가적인 DB 조회가 필요하기 때문에 트래픽이 많을 경우 성능 저하를 유발할 수 있습니다.
- 높은 동시성 상황에서는 중복 여부를 확인한 뒤 다른 스레드가 저장을 시도할 수 있어, 여전히 중복 예외가 발생할 수 있습니다.
- 성능 문제가 발생할 수 있습니다. 추가적인 DB 조회가 필요하기 때문에 트래픽이 많을 경우 성능 저하를 유발할 수 있습니다.
- 장점:
예외 발생 후 처리(try-catch로 예외 처리):
- 장점:
- 간단합니다. 한번의 시도를 통해 원하는 결과를 얻거나 예외로 처리할 수 있습니다.
- DB의 트랜잭션과 직접적으로 연결되기 때문에, 동시성 문제를 상대적으로 안전하게 처리할 수 있습니다.
- 간단합니다. 한번의 시도를 통해 원하는 결과를 얻거나 예외로 처리할 수 있습니다.
- 단점:
- 예외가 발생할 때마다 코드가 복잡해지며, 예외 처리 로직이 코드의 주요 흐름을 방해할 수 있습니다.
- 여러 번의 시도가 필요한 경우 반복적인 트랜잭션이 발생할 수 있어 성능에 영향을 미칠 수 있습니다.
- 예외가 발생할 때마다 코드가 복잡해지며, 예외 처리 로직이 코드의 주요 흐름을 방해할 수 있습니다.
- 장점:
최종적으로, 어떤 방법이 더 적합한지는 애플리케이션의 요구사항, 성능 요구, 데이터 일관성 요구에 따라 달라질 수 있습니다. 개인적으로 사전 조회보다는 예외 처리를 통해 트랜잭션을 유지하고 로직을 관리하는 방식이 더 안전하다고 생각될 수 있지만, 이는 상황에 따라 다르게 평가될 수 있습니다.
아래는 비슷한 주제를 다룬 질문과 답변 링크입니다. 참고하시길 바랍니다:
1. save시 중복 pk 값 입력 검증?
2. 7:30 DuplicateKeyException 질문
3. Unique Index 데이터 저장에 대해서 질문드립니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
spring initialiser 어떤걸 선택해야될지 모르겠어요
0
32
2
트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.
0
51
1
jdbc 학습하다 궁금해서 질문드려요
0
82
1
정상이체와 이체중 예외발생 차이
0
68
2
이번 강의부터가 JDBC 직접 사용 맞나요?
0
88
1
순수한 서비스 계층에 대한 의문???
0
82
2
3_4test, 4test 자동 리소스 안됨
0
58
2
데이터베이스 선택 관련 질문.
0
68
2
after 메서드 사용 유무
0
57
2
데이터베이스 접근 및 DB 락
0
55
1
@SpingBootTest, @TestConfiguration
0
56
1
Read Committed 격리 수준 사용 관련 질문
0
48
1
AopCheck Test 부분의 EnhancerBySpring 확인 법??
0
66
2
커리큘럼 관련 질문
0
76
1
서비서 계층 스프링 프레임워크 사용
0
88
1
validation(toMember)의 위치
0
83
2
데이터 계층에서 서비스 로직의 datasource를 인식하는 방법
0
165
2
member 상수 질문
0
121
2
ctrl + F6 이후로 con 인식이 안 됩니다
0
153
2
DrivenManager 와 Connection 반환에 대한 질문입니다!
0
109
1
섹션5 트랜잭션 템플릿관련 질문(이기종 DB)
0
116
1
세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?
0
100
1
트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?
0
98
1
강의 14분쯤 Exception 질문
0
115
2





