inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 2편 - 데이터 접근 활용 기술

트랜잭션 관련해서 질문 있습니다.

1550

호롤롤로

작성한 질문수 5

0

안녕하세요 유익한 강의 잘 듣고 있습니다!

 

트랜잭션 관련해서 질문 있습니다.

[질문 1]

만약 아래와 같은 코드가 있다고 했을 때

JdbcTemplate jdbcTemplate = new JdbcTemplate(targetDataSource);
PlatformTransactionManager transactionManager = new DataSourceTransactionManager(targetDataSource);
DefaultTransactionDefinition definition = new DefaultTransactionDefinition();
TransactionStatus status = transactionManager.getTransaction(definition);
boolean isRollback = false;

//100개의 테이블 리스트를 순회
for (String table : tableList) {
    try {
        String query = "임의의 쿼리";
       jdbcTemplate.execute(query);
    } catch (Exception e) {
        log.error(e.getMessage());
        isRollback = true;
    }
}

if (isRollback) transactionManager.rollback(status);
else transactionManager.commit(status);

 

100개의 테이블을 순회해서 어떠한 쿼리를 실행해보고 싶은데, 100개의 쿼리 중 하나의 쿼리라도 실패하는 순간 그 뒤의 쿼리들은 전부 오류가 떨어집니다.

오류 내용은 아래와 같습니다.

"오류: 현재 트랜잭션은 중지되었습니다. 이 트랜잭션을 종료하기 전까지는 모든 명령이 무시될 것입니다."

제가 생각하기로는 앞선 쿼리에서 오류가나서 트랜잭션이 롤백되었으니 나머지 쿼리를 실행해보지 않아도 롤백되기 때문에 실행해보지 않고 무시하겠다는 의미 같은데...

저는 오류가 나더라도 우선 100개의 쿼리는 잘 돌아가고 마지막에 rollback처리를 하고 싶은데 방법이 있을까요? (오류가 100개의 쿼리 각각 어떠한 오류로 인한 실패인지 확인하고 싶기 때문입니다.)

 

[ 질문 2]

rollbackFor 옵션을 애노테이션 옵션말고 코드로 설정할 수 있나요?

마치 propagation 옵션을 아래와 같이 설정한 것처럼 코드로 설정할 수 있나요?

definition.setPropagationBehavior(PROPAGATION_REQUIRES_NEW);

spring

답변 1

0

김영한

안녕하세요. newleader95님

질문1

이 부분은 저도 잘 모르겠습니다. 그런데 이미 트랜잭션이 실패했는데, 실행하는 것 자체가 의미가 없습니다. 따라서 이 부분은 추가로 더 실행하는게 크게 의미가 없을 듯 합니다.

질문2

다음을 참고해주세요.

https://stackoverflow.com/questions/69329687/how-to-set-norollbackfor-on-a-transactiontemplate

감사합니다.

0

호롤롤로

답변 감사합니다!

설정 정보 없이 임베디드 데이터베이스 생성

0

20

1

RepositoryTest의 패키지 위치가 domain인 이유

0

39

2

REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!

0

32

1

update()에 사용하는 setter 질문드립니다.

0

49

1

SQL 중심적 개발의 문제점에 대한 질문

0

79

1

혹시 Containing 을 안쓰신 이유가 있을까요?

0

89

2

[공유] 스프링부트 4.x 버전 mybatis 연동

0

184

1

@repository 어노테이션

0

94

3

ItemService

0

59

1

논리 커밋, 물리 커밋 질문드립니다.

0

54

1

내부 트랜잭션 커밋은 필수인가요?

0

57

1

프록시 커넥션 객체를 반환할 때 생성하는건가요?

0

55

1

Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)

2

180

2

JPQL 대신 네이티브 쿼리를 사용해야 하는 경우

0

81

1

@EventListener(ApplicationReadyEvent.class) 관련

0

91

1

트랜잭션 동기화 매니저와 데이터 소스

0

77

1

DB 관련 강의 개설 계획은 없으신건가요?

0

134

2

물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요

0

96

1

스프링 3 버전 이상 rollbackFor 변경된듯요

1

115

1

트랜잭션 전파 질문.

0

87

1

프로젝트 오픈 에러

0

126

1

외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다

0

84

2

같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환

0

74

1

h2 인메모리 테스트중 예약어 충돌날 경우 대처방법

0

105

1