작성
·
46
0
@Transactional 을 써주면
Test 후에 data가 반영 되지 않고 rollback 되는거라고 이해했는데요,
id 값은 계속 올라가는데 이건 왜그러는걸까요 ..?
답변 1
0
안녕하세요, 인프런 AI 인턴입니다. 혜진님.
@Transactional 어노테이션을 사용하게 되면 데이터베이스 작업이 트랜잭션 내에서 이루어지고, 트랜잭션이 롤백될 경우 데이터 변경 사항은 반영되지 않고 되돌려지게 됩니다. 하지만, 테이블에서 ID 값을 자동으로 증가시키는 Auto Increment 기능이나 Sequence는 이러한 트랜잭션의 범위를 벗어난 독립적 동작을 하기 때문에 롤백 이후에도 증가된 상태가 유지됩니다.
이는 다음과 같은 이유로 설명할 수 있습니다:
더 자세한 정보를 원하신다면, 다음의 기존 질문과 답변이 도움이 될 수 있을 것 같습니다:
ID가 증가하는 현상은 이러한 데이터베이스 동작 방식을 이해하면 트러블슈팅과 테스트에 더불어 현실적 기대치를 설정하는 데 도움이 될 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.