inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

서버 재실행시 db데이터 리셋에 대해 궁금한점이있습니다.

해결된 질문

362

skh990427

작성한 질문수 3

0

웹 계층 개발챕터 강의를 진행하고 있는 수강생입니다.

문득 궁금한점이 생겨 질문 남기게되었습니다.

코드를 작성하고 서버를 재실행하면 기존에 db에 넣어둔 데이터가 다 날아가고 없어지는게 서비스로직에 달려있는 @Transactional 어노테이션 때문인가요?

테스트코드에서의 @Trasactional 어노테이션의 경우 테스트데이터의 경우 테스트만 진행하고 테스트된 데이터는 db에 반영을 하지 않기위해서(Rollback) 사용한다고 알고있습니다.

그래서 원래 코드에서도 반영이 되지않는 이유가 서비스로직에 포함된 트랜잭션 어노테이션 때문인지 궁금하여 질문드립니다.

 

java spring 웹앱 spring-boot jpa

답변 2

1

David

안녕하세요. skh990427님, 공식 서포터즈 David입니다.

application.yml 내 ddl-auto:create 옵션으로 인해 애플리케이션 실행 단계에서 테이블들이 새롭게 만들어집니다.

감사합니다.

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요. 데이터베이스의 데이터가 서버 재실행 시에 사라지는 이유에 대해 궁금하신 것 같아요.

서버를 재실행하면 일반적으로 메모리 상에 있던 데이터가 모두 초기화되기 때문에 데이터베이스에 저장되어 있던 데이터도 사라지게 되요. 따라서 재실행 이후에는 데이터를 다시 추가해야 합니다.

@Transactional 어노테이션은 데이터베이스 트랜잭션을 관리해주는 역할을 해요. 트랜잭션이란 여러 개의 데이터 작업을 하나의 논리적인 작업 단위로 묶는 개념이에요. @Transactional 어노테이션은 트랜잭션이 포함된 메서드가 실행될 때 데이터베이스의 상태를 변화시키는 변경 작업을 하거나, 트랜잭션의 실행 결과를 롤백할 지 커밋할 지를 결정하는 역할을 해요.

따라서 서비스 로직에서 @Transactional 어노테이션이 사용된 경우, 해당 메서드가 실행되는 동안의 모든 데이터 작업은 트랜잭션에 묶여있기 때문에 롤백되거나 커밋되지 않으면 변경 내용이 데이터베이스에 반영되지 않아요. 이로 인해 서버를 재실행해도 변경된 데이터가 데이터베이스에 영구적으로 저장되지 않게 됩니다.

하지만 주의해야 할 점은, @Transactional 어노테이션을 사용하여 롤백이나 커밋을 수행할 때는 관리되는 트랜잭션 범위 내에서만 트랜잭션 처리가 되는 것이기 때문에, 재실행 이후에는 트랜잭션 범위를 벗어나 데이터베이스에 변경된 내용이 영구적으로 반영되지 않을 수 있습니다.

저의 답변이 도움이 되셨길 바라며, 추가로 궁금한 점이 있으면 언제든지 물어보세요. 좋은 하루 되세요!

sdk 설정 오류

0

53

2

오탈자 - @Transactional

0

56

1

src/test/resources 테스트 경로 문제

0

50

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

64

1

MemberRepositoryTest 실행오류

0

81

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

184

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

142

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

52

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

72

1

기본 생성자

0

60

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

103

1

멤버서비스테스트 부분에서 막힙니다.

0

165

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

116

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

120

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

114

1

24분 27초 연관관계 편의 메서드 위치

0

113

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

109

2

빌드 툴, Gradle

0

59

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

77

2

Repository에서 EntityManager 주입 방식 차이

0

90

1

롬복과 사용자 정의 setter 메서드

0

73

1

주문 목록 조회 fetch join 질문드립니다

0

82

1

dirty checking 질문드립니다.

0

83

1

동시성 관련 질문입니다

0

75

1