Inflearn brand logo image

인프런 커뮤니티 질문&답변

혜진님의 프로필 이미지
혜진

작성한 질문수

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

스프링 통합 테스트

ID는 Transactional 으로 rollback이 안되나요 ?

작성

·

46

0

@Transactional 을 써주면
Test 후에 data가 반영 되지 않고 rollback 되는거라고 이해했는데요,

id 값은 계속 올라가는데 이건 왜그러는걸까요 ..?

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. 혜진님.

@Transactional 어노테이션을 사용하게 되면 데이터베이스 작업이 트랜잭션 내에서 이루어지고, 트랜잭션이 롤백될 경우 데이터 변경 사항은 반영되지 않고 되돌려지게 됩니다. 하지만, 테이블에서 ID 값을 자동으로 증가시키는 Auto Increment 기능이나 Sequence는 이러한 트랜잭션의 범위를 벗어난 독립적 동작을 하기 때문에 롤백 이후에도 증가된 상태가 유지됩니다.

이는 다음과 같은 이유로 설명할 수 있습니다:

  • ID 생성 전략: 데이터베이스는 ID를 식별자로 사용하기 위해 Auto Increment 또는 Sequence를 이용해 값을 참조합니다. 이러한 값들은 트랜잭션과 무관하게 매번 증가합니다. 즉, 롤백이 되더라도 ID 증가는 되돌려지지 않습니다.

더 자세한 정보를 원하신다면, 다음의 기존 질문과 답변이 도움이 될 수 있을 것 같습니다:

  1. @Transactional generate key 질문 - 회원님께서 경험하신 것과 같은 문제가 발생한 경우에 대한 다른 사용자의 질문과 답변입니다.
  2. 스프링 통합 테스트 시 @Transactional로 DB를 롤백 시키는데 id는 여전히 건너뛰어지는 이유 - 트랜잭션 롤백 후에도 ID가 건너뛰어지는 현상에 대한 구체적인 설명이 있습니다.

ID가 증가하는 현상은 이러한 데이터베이스 동작 방식을 이해하면 트러블슈팅과 테스트에 더불어 현실적 기대치를 설정하는 데 도움이 될 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

혜진님의 프로필 이미지
혜진

작성한 질문수

질문하기