inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

DataSource 예제1 - DriverManager

테스트 코드에서 Connection.close 메서드를 호출해주지 않아도 괜찮나요?

해결된 질문

593

김회민

작성한 질문수 6

0

안녕하세요.

이번 수업 시간에 테스트 코드를 통해 커넥션 예제를 보여주셨는데, 코드 상으로는 close 메서드를 호출해주지 않으셔서 질문 남깁니다.

@Slf4j
public class ConnectionTest {
    /**
     * DriverManager
     */
    @Test
    void driverManager() throws SQLException {
        Connection con1 = DriverManager.getConnection(URL, USERNAME, PASSWORD);
        Connection con2 = DriverManager.getConnection(URL, USERNAME, PASSWORD);
        log.info("con1: class = {}, connection = {}", con1.getClass(), con1);
        log.info("con2: class = {}, connection = {}", con2.getClass(), con2);
    }

    /**
     * DataSourceDriverManager
     */
    @Test
    void dataSourceDriverManager() throws SQLException {
        // DriverManagerDataSource - 항상 새로운 커넥션 획득
        DriverManagerDataSource dataSource = new DriverManagerDataSource(URL, USERNAME, PASSWORD);
        Connection con1 = dataSource.getConnection();
        Connection con2 = dataSource.getConnection();
        log.info("con1: class = {}, connection = {}", con1.getClass(), con1);
        log.info("con2: class = {}, connection = {}", con2.getClass(), con2);
    }
}

close 메서드를 호출해주지 않아도 내부적으로 알아서 커넥션을 제거해주는 것 같은데, 혹시 이에 대한 보충 설명을 해주실 수 있을까요..?

spring

답변 1

2

김영한

안녕하세요. 김회민님

여기서는 간단히 테스트만 하고 넘어가기 때문에 생략한 것이고, 원칙적으로 커넥션을 종료해주셔야 합니다.

테스트가 완전히 종료되는 JVM도 종료되기 때문에 이때 커넥션도 반환됩니다.

감사합니다.

0

김회민

답변 감사드립니다. JVM이 종료하면서 커넥션도 자동적으로 반환해주는 군요!

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

0

43

2

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

0

55

1

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

0

87

1

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

0

73

2

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

0

91

1

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

0

84

2

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

0

61

2

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

0

73

2

after 메서드 사용 유무

0

64

2

데이터베이스 접근 및 DB 락

0

59

1

@SpingBootTest, @TestConfiguration

0

59

1

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

0

53

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

70

2

커리큘럼 관련 질문

0

79

1

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

0

90

1

validation(toMember)의 위치

0

84

2

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

0

167

2

member 상수 질문

0

126

2

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

0

158

2

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

0

112

1

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

0

117

1

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

0

104

1

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

0

99

1

강의 14분쯤 Exception 질문

0

117

2