inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

데이터 접근 예외 직접 만들기

예외처리

해결된 질문

205

해톨

작성한 질문수 33

0

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

try 구문안에서 예외가 발생하면 밑에있는 try의 남은 구문 건너뛰고 바로 catch문으로가서 잡아주는것으로 알고있습니다.

그런데 공부하다보니까 헷갈리는게 MemberRepository에 있는 save메서드로 예를 들면,

con.prepareStatement(sql)부터 SQLException을 발생시키는데 어떻게 try안에 있는 것들이 정상적으로 수행되는지 궁금합니다.

예외가 나오는 순간 catch문으로가서 catch구문을 수행하는 것이 아닌가요 ??

 @Override
    public Member save(Member member) {
        String sql = "insert into member(member_id,money) values(?,?)";

        Connection con = null;
        PreparedStatement pstmt = null;

        try {
            con = getConnection();
            pstmt = con.prepareStatement(sql);
            pstmt.setString(1, member.getMemberId());
            pstmt.setInt(2, member.getMoney());
            pstmt.executeUpdate(); //수정
            return member;
        } catch (SQLException e) {
            log.error("db error", e);
            throw new MyDbException(e);
        }finally {
            close(con, pstmt, null);
        }
    }

spring mvc spring-jdbc

답변 1

1

y2gcoder

안녕하세요. 해톨님, 공식 서포터즈 y2gcoder입니다.

제가 해톨님의 설명을 제대로 이해한 것인지 모르겠습니다!

try 구문안에서 예외가 발생하면 밑에있는 try의 남은 구문 건너뛰고 바로 catch문으로가서 잡아주는것으로 알고있습니다.

=> try 블럭 내에서 예외가 발생하면 그 밑의 라인은 수행되지 않습니다. 그리고 catch 블럭에서 해당 예외를 잡아주고 있다면 catch 블럭에서 다음 로직을 수행하는 것이고 그렇지 않다면 해당 블럭 바깥으로 던져진다고 이해해주시면 좋을 것 같습니다 🙂

그런데 공부하다보니까 헷갈리는게 MemberRepository에 있는 save메서드로 예를 들면,

con.prepareStatement(sql)부터 SQLException을 발생시키는데 어떻게 try안에 있는 것들이 정상적으로 수행되는지 궁금합니다.

예외가 나오는 순간 catch문으로가서 catch구문을 수행하는 것이 아닌가요 ??

=> 말씀해주신 것과 같이 try 문 안에서 예외가 발생하면 try 문 블럭 내부의 다음 코드는 실행되지 않습니다 🙂 정상적으로 실행되지 않고, SQLException(혹은 그 하위 예외)이라면 catch 문에서 처리된 후 정상흐름으로 save()를 종료해주는 것입니다!

 

감사합니다.

0

해톨

감사합니다 !!

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

31

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

50

1

jdbc 학습하다 궁금해서 질문드려요

0

82

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

87

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

54

1

@SpingBootTest, @TestConfiguration

0

56

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

87

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

120

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

109

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

98

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

114

2