inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

다음으로

autoCommit(false)시 conn.rollback()은 필요 없나요?

899

GJ S

작성한 질문수 1

1

안녕하세요. 강의 늘 잘 보고 있습니다. 1편을 다 마치게 되어서 손으로 jdbc~트랜잭션 추상화까지 직접 테스트 코드를 짜보고 있는데요.

일부러 같은 pk를 넣어 익셉션이 터지도록 의도하고, 롤백이 되길 원했습니다.

그런데 코드를 들여다보니 rollback() 구문을 빠트리고 작성했는데도 원하는 대로 롤백이 되었습니다.

void multiSave(List<Member> members) throws SQLException {
    Connection conn = DriverManager.getConnection(URL, USERNAME, PASSWORD);
    try {
        conn.setAutoCommit(false);
        for (Member member : members) {
            repository.save(conn, member);
        }
        conn.commit();
    } catch (SQLException e) {
        log.error("log message = {}", e);
        throw new RuntimeException();
    } finally {
        JdbcUtils.closeConnection(conn);
    }
}

사실 autocommit true가 아니니까 이렇게 처리해주는 것이 당연한 것 같으면서도, 개발자가 명시하지 않아도 동작하는 거라면 rollback()이 왜 있는 건가요? 다른 쓰임새가 또 있는걸까요?

spring

답변 1

3

김영한

안녕하세요. GJ S님

롤백은 직접 롤백을 호출하거나 또는 커밋이 정상 호출되지 않으면 롤백됩니다.

롤백을 빠르게 하는 이유는 데이터베이스에 롤백을 최대한 빨리 알려주어야 데이터베이스가 기존에 잡고 있던 리소스를 빠르게 복귀하기 때문입니다.

감사합니다.

0

GJ S

감사합니다. 저같이 미숙한 초보 개발자와는 인사이트가 다르신 것에 늘 감탄합니다.

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

0

43

2

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

0

56

1

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

0

88

1

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

0

75

2

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

0

91

1

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

0

84

2

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

0

62

2

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

0

73

2

after 메서드 사용 유무

0

65

2

데이터베이스 접근 및 DB 락

0

59

1

@SpingBootTest, @TestConfiguration

0

59

1

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

0

54

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

70

2

커리큘럼 관련 질문

0

79

1

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

0

90

1

validation(toMember)의 위치

0

86

2

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

0

167

2

member 상수 질문

0

128

2

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

0

159

2

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

0

113

1

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

0

117

1

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

0

104

1

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

0

99

1

강의 14분쯤 Exception 질문

0

117

2