• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    해결됨

트랜잭션이 적용되지 않는 메소드에 대해서 궁금합니다.

23.04.06 23:52 작성 23.04.06 23:57 수정 조회수 424

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
강의에서는 accountTransfer 메소드에 @Transactional을 붙여서 트랜잭션 관리가 되도록 했는 데 만약에 같은 클래스에서 @Transactional이 붙어 있지 않는 메소드에서는 트랜잭션 매니저를 거치는 지, 만약 거치지 않는 다면 어떻게 작동하는 지 궁금합니다.

답변 1

답변을 작성해보세요.

0

y2gcoder님의 프로필

y2gcoder

2023.04.07

안녕하세요, 백승진 님. 공식 서포터즈 y2gcoder 입니다.

@Transactional 어노테이션은 트랜잭션을 관리하기 위해 사용되며, 이 어노테이션이 붙은 메소드가 실행되면 트랜잭션 매니저가 해당 메소드를 실행할 때 트랜잭션을 시작하고 종료합니다. 만약 같은 클래스의 다른 메소드에서 @Transactional이 붙어 있지 않다면, 그 메소드는 트랜잭션 매니저를 거치지 않고 실행됩니다.

@Transactional이 없는 메소드가 실행될 때 일어나는 상황은 다음과 같습니다:

  1. 해당 메소드는 트랜잭션 매니저를 사용하지 않으므로, 데이터베이스 연산에 대한 트랜잭션 처리가 일어나지 않습니다.

  2. 메소드 내에서 발생하는 데이터베이스 변경은 즉시 커밋됩니다. 오류가 발생하면 이미 커밋된 변경 사항은 자동으로 롤백되지 않습니다.

즉, @Transactional이 붙어 있지 않은 메소드에서는 트랜잭션 관리가 되지 않으므로, 데이터 일관성과 롤백을 보장할 수 없습니다. 데이터베이스 변경 작업이 포함된 메소드의 경우, 적절한 트랜잭션 관리를 위해 @Transactional 어노테이션을 사용하는 것이 좋습니다.

@Transactional이 붙은 메서드에서 같은 클래스의 다른 메서드를 호출하면 해당 메서드는 트랜잭션이 걸리는지, @Transactional이 붙지 않은 메서드에서 같은 클래스의 @Transactional이 붙은 메서드를 호출하면 @Transactional이 붙은 메서드는 트랜잭션이 걸리는지에 대해서는 DB 2편 강의를 참고해보시면 확실하게 답을 알고 가실 수 있을 거라 생각합니다.

감사합니다.