inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

예외처리 관련 질문이 있습니다.

163

kd park

작성한 질문수 3

0

안녕하세요 강의 잘 보고있습니다.

다름이 아니라 강의 중 시스템 예외상황이 아닌 비지니스 예외상황(ex. 중복멤버처리, 강의엔 없지만 만료쿠폰사용 등등)에서

exception을 던져 처리하시는 것으로 봤는데 제가 배우기로는 일반적으로 IO 등이 아닌 개발자가 예상가능한 상황에 대해서는

예외를 던지지 않고 null이나 값을 리턴함으로서 처리하는 것으로 알고 있습니다. 

exception should be exceptional 이라는 구절처럼 말이죠.

혹시 해당 강의와 관련이 없는 부분이라 단순화 시켜 편의상 처리하신 것인지

아니면 실제로 실무에서는 exception을 던지는 것이 관행인지(외래키는 거는것이 정도이지만 그렇지않는 경우도 있는 것처럼)

궁금하여 글을 남깁니다. 감사합니다.

JPA 웹앱 spring spring-boot java

답변 1

1

김영한

안녕하세요. kd park님

강의에서는 편의상 예외를 반환한 것이 맞습니다. 안그러면 상태를 반환하는 리턴 값으로 처리하는 복잡한 로직이 들어갔겠지요?

이 부분은 상황이나 사람마다 생각이 조금씩 다르다고 생각됩니다.

그래서 제가 선호하는 방법을 말씀드릴께요. 이 부분은 정답이라기 보다는 개인적인 생각입니다.

저도 가급적 예외를 터트리지 않고, 앞에서 한번 체크하는 방식을 선호합니다. 다만 심각한 비즈니스 상황에서는 예외를 발생시키도록 클래스를 설계합니다. 예를 들어서 만료 쿠폰의 경우 앞에서 한번 만료인지 아닌지 체크하는 로직과, 그리고 실제 그 쿠폰을 사용하는 로직으로 분리되어 있으면, 체크하는 로직에서 대부분 걸려서 예외가 발생하지 않겠지요. 이렇게 예외가 발생하는 상황을 줄이고, 그래도 누군가 실수로 쿠폰을 체크하는 로직을 누락하고 쿠폰을 사용하는 로직을 호출한다면, 예외를 발생 시키는 것이 안전한 설계라 생각합니다.

감사합니다^^

sdk 설정 오류

0

49

2

오탈자 - @Transactional

0

55

1

src/test/resources 테스트 경로 문제

0

50

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

63

1

MemberRepositoryTest 실행오류

0

79

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

183

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

137

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

51

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

60

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

100

1

멤버서비스테스트 부분에서 막힙니다.

0

164

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

116

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

118

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

112

1

24분 27초 연관관계 편의 메서드 위치

0

113

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

108

2

빌드 툴, Gradle

0

58

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

75

2

Repository에서 EntityManager 주입 방식 차이

0

88

1

롬복과 사용자 정의 setter 메서드

0

71

1

주문 목록 조회 fetch join 질문드립니다

0

81

1

dirty checking 질문드립니다.

0

81

1

동시성 관련 질문입니다

0

73

1