IncorrectResultSizeDataAccessException
470
작성한 질문수 15
'JdbcTemplate 적용1- 기본' 강의에서 findById()를 설명하실때,
'결과가 없을경우'는 catch로 예외처리를 해주시는데
'둘 이상일 경우' IncorrectResultSizeDataAccessException에 대해서는 왜 catch문으로 예외처리를 하지 않는것인지 궁금합니다.
답변 1
0
안녕하세요. jeong정재인님, 공식 서포터즈 y2gcoder입니다.
findById()라는 메서드는 사실 결과 없음 / 결과 하나 라는 두 가지 케이스의 응답을 가정한다고 생각합니다. 메서드의 만들어진 목적으로 볼 때, 결과가 없을 때 반환하는 EmptyResultDataAccessException 는 findById() 입장에서 쿼리 결과가 없을 때 나올 수 있는 일반적인 상황이므로 Optional.empty()를 이용해 명시적으로 처리해주는게 맞다고 생각합니다.
반면에 둘 이상일 경우 발생하는 IncorrectResultSizeDataAccessException 는 findById 입장에서는 전혀 정상적인 상황이 아닙니다. 뭔가 개발자가 짠 로직에 문제가 있는 것이고, 데이터의 무결성이 깨진 상황이라 볼 수 있습니다. 이러한 경우는 디버깅과 수정이 필요한 상황이기 때문에 예외를 try catch문에서 먹지 않고 던져주어 프로그램의 진행을 막아주는 것이 좋다고 생각합니다. 그래야 개발자가 문제 상황을 인지할 수 있기 때문입니다.
물론 그럼에도 불구하고 비즈니스 로직 상황에 따라 IncorrectResultSizeDataAccessException 를 명시적으로 처리해줘야 한다면 catch 블록을 추가해서 처리해줄 수는 있습니다. 다만 이번 findById()에서는 이렇게 처리하는 것이 좀 더 맞지 않나 조심스럽게 생각해봤습니다.
감사합니다.
RepositoryTest의 패키지 위치가 domain인 이유
0
30
2
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
30
1
update()에 사용하는 setter 질문드립니다.
0
48
1
SQL 중심적 개발의 문제점에 대한 질문
0
72
1
혹시 Containing 을 안쓰신 이유가 있을까요?
0
84
2
[공유] 스프링부트 4.x 버전 mybatis 연동
0
176
1
@repository 어노테이션
0
89
3
ItemService
0
58
1
논리 커밋, 물리 커밋 질문드립니다.
0
54
1
내부 트랜잭션 커밋은 필수인가요?
0
57
1
프록시 커넥션 객체를 반환할 때 생성하는건가요?
0
54
1
Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)
2
178
2
JPQL 대신 네이티브 쿼리를 사용해야 하는 경우
0
79
1
@EventListener(ApplicationReadyEvent.class) 관련
0
88
1
트랜잭션 동기화 매니저와 데이터 소스
0
76
1
DB 관련 강의 개설 계획은 없으신건가요?
0
133
2
물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요
0
94
1
스프링 3 버전 이상 rollbackFor 변경된듯요
1
112
1
트랜잭션 전파 질문.
0
87
1
프로젝트 오픈 에러
0
126
1
외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다
0
84
2
같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환
0
73
1
h2 인메모리 테스트중 예약어 충돌날 경우 대처방법
0
102
1
커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문
0
98
2





