inflearn logo
강의

講義

知識共有

Spring DB 1編 - データアクセスの中心原理

JDBC 開発 - 更新、削除

Connection, pstmt 질문입니다

494

작성자 없음

投稿した質問数 0

0

public void aaa() throws SQLException {
    String sql = "delete from member where member_id =?";
    String memberId = "!";
    try {
        Connection con = getConnection();
        PreparedStatement pstmt = null;
        pstmt = con.prepareStatement(sql);
    } catch (Exception e) {
        
    }
}

이렇게 try 문 안에서 한번에 받지 않고

Connection con = null;
PreparedStatement pstmt = null;

이렇게 null로 외부에서 선언을 하는 것은 finally 문 안에 close 메서드에 파라미터로 넘겨주기 위함이 맞나요 ?

spring

回答 2

4

hjoo

맞아요! 코드에서 ConnectionPreparedStatement를 외부에서 null로 선언하고 있는 이유는, 주로 다음과 같은 상황 때문이에요.

  1. try 블록 안에서 발생하는 예외를 처리하면서, catch 블록에서도 이 변수들에 접근할 수 있어요.

  2. finally 블록에서 이 변수들을 사용해 자원을 안전하게 닫아주기 위해서예요. finally 블록은 예외가 발생하든 안 하든 실행되기 때문에, 이렇게 하면 코드가 깔끔하게 정리돼요.

finally {
    if (pstmt != null) {
        try {
            pstmt.close();
        } catch (SQLException e) {
            // 예외 처리
        }
    }
    if (con != null) {
        try {
            con.close();
        } catch (SQLException e) {
            // 예외 처리
        }
    }
}

이렇게 하면 코드가 더 안전하고 깔끔해져요!

1

yh

인프런 대표님께서 직접 답글을 달아주시다니 ㅋㅋㅋ 감사합니다.

2

y2gcoder

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

대표님께서 달아주신 것 이상의 답변을 드릴 수 없을 것 같습니다 :)

감사합니다.

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

0

31

2

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

0

50

1

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

0

81

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

97

1

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

0

98

1

강의 14분쯤 Exception 질문

0

114

2