강의

멘토링

로드맵

Inflearn brand logo image

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

ajdsasld님의 프로필 이미지
ajdsasld

작성한 질문수

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

다음으로

트랜잭션과 관련된 질문입니다!

작성

·

112

0

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

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

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

"JPA 사용 시 주의해야할 점은, 항상 “트랜잭션”이 있어야 한다"

라고 해주셨는데, 그 말의 의미가 애플리케이션 서버가 DB 서버에 연결해서 데이터 관련 작업(쿼리를 날리는 등)시 무조건 트랜잭션이 필요하다는 말인가요?

즉, JPA가 아닌 JDBC Template을 사용하더라도 무조건 DB와의 데이터 관련 작업 시 “트랜잭션”이 있어야 하나요?

어떤 메서드엔 @Transactional이 없어도 되었고 어떤 메서드엔 필요했던 기억이 있어서 여쭤봅니다!

 

그리고, 트랜잭션이 걸려있을 때 애플리케이션에서 DB 서버로 쿼리를 날릴 때,

"트랜잭션이 실행되고 DB에 쿼리가 날라가고 commit이 되서 DB에 데이터가 들어가는 순서" 일까요?

 

답변 1

1

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

트랜잭션은 데이터베이스 작업의 일관성을 보장하기 위해 매우 중요한 요소입니다. JPA와 같은 ORM 도구나 JDBC Template을 통해 데이터베이스와 상호작용할 때, 데이터 변경이 발생하는 경우에는 항상 트랜잭션이 요구됩니다. 이는 데이터의 일관성을 유지하고, 작업의 원자성을 보장하기 위함입니다.

  1. 트랜잭션의 필요성:

    • JPA를 사용할 때뿐만 아니라, JDBC Template 등을 사용할 때도 데이터 조작(insert, update, delete)에는 트랜잭션이 필수적입니다. 이는 데이터 작업의 오류가 발생할 때 롤백을 가능하게 하여 데이터의 무결성을 유지하기 위한 것입니다.
    • 반면, 단순 조회의 경우, 트랜잭션이 없어도 데이터 일관성에는 문제가 없으나, 읽기 작업 사이의 일관성을 위해 트랜잭션을 사용하기도 합니다.
  2. @Transactional 애노테이션:

    • 특정 메서드에 @Transactional이 필요한 이유는 해당 메서드가 데이터 조작 작업을 포함하기 때문입니다. 데이터의 일관성과 무결성을 보장하기 위해 모든 데이터 조작 로직은 트랜잭션 내에서 실행되어야 합니다.
  3. 트랜잭션의 순서:

    • 트랜잭션이 시작되면, 데이터베이스 연결이 열리고 필요한 모든 쿼리가 실행됩니다. 모든 작업이 성공적으로 완료되면 커밋을 통해 데이터베이스에 반영됩니다. 문제가 발생할 경우 롤백됩니다.

아래의 링크에서 추가 정보를 확인하시면서, 트랜잭션의 중요성과 적용 방법에 대해 더 이해해 보시기 바랍니다.

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

ajdsasld님의 프로필 이미지
ajdsasld

작성한 질문수

질문하기