[JPA와 DB 설정, 동작확인] 왜 insert가 안되는지 궁금합니다.
374
작성한 질문수 16
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
안녕하세요, 테스트가 정상적으로 실행되었으며 @Rollback 어노테이션을 붙였음에도 불구하고 왜 데이터가 insert 되지 않는지 궁금합니다.
관련 사진은 다음과 같습니다.



코드는 다음과 같습니다.
package jpabook.jpashop;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.annotation.Rollback;
import org.springframework.test.context.junit4.SpringRunner;
import org.springframework.transaction.annotation.Transactional;
import static org.junit.jupiter.api.Assertions.*;
@RunWith(SpringRunner.class)
@SpringBootTest
class MemberRepositoryTest {
@Autowired
MemberRepository memberRepository;
@Test
@Transactional
@Rollback(false)
public void testMember() throws Exception {
// given
Member member = new Member();
member.setUsername("memberA");
// when
Long saveId = memberRepository.save(member);
Member findMember = memberRepository.find(saveId);
// then
Assertions.assertThat(findMember.getId()).isEqualTo(member.getId());
Assertions.assertThat(findMember.getUsername()).isEqualTo(member.getUsername());
}
}spring:
datasource:
url: jdbc:h2:tcp://localhost/~/jpashop
username: sa
password:
driver-class-name: org.h2.Driver
jpa:
hibernate:
ddl-auto: update
properties:
hibernate:
#show_sql: true
format_sql: true
logging.level:
org.hibernate.SQL: debug
#org.hibernate.type: trace
감사합니다.
답변 2
0
안녕하세요. 김민석님, 공식 서포터즈 OMG입니다.
test폴더 경로에 application.yml 을 추가하셨네요 😀
test 경로에 있는 yml을 지우고 확인해보시겠어요?
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
김민석님, JPA와 DB 설정, 동작확인 과정에서 데이터가 실제로 insert되지 않는 문제가 발생하신다고 하셨네요. 이와 같은 문제는 주로 트랜잭션 설정이나 데이터베이스 연결 설정에서 비롯될 수 있습니다. 아래의 몇 가지 유사한 상황을 통해 답변을 드리도록 하겠습니다.
일반적인 해결 방법:
트랜잭션 설정 및 확인:
@Transactional어노테이션이 정상 작동하는지 확인하세요. 테스트 메소드가 끝난 후 별다른 예외가 없다면, 기본적으로 롤백되지 않고 커밋됩니다.
@Rollback(false)를 사용하여 명시적으로 롤백을 방지하고 있다면, 데이터는 삽입되어야 합니다.
Hibernate 설정 확인:
spring.jpa.hibernate.ddl-auto속성 값이 ‘update’로 설정되어 있습니다. 이는 테이블 구조가 업데이트되더라도 데이터가 손실되지 않도록 해주지만, 데이터 삽입과는 무관합니다.
logging.level.org.hibernate.SQL을debug로 설정한 후, Hibernate SQL 로그를 확인하여 쿼리가 올바르게 실행되는지 체크해 보세요.
H2 데이터베이스 설정:
- 휘발성 메모리 데이터베이스를 사용하고 있다면, 같은 연결 세션이 아니면 데이터가 유지되지 않을 수 있습니다.
jdbc:h2:mem:~/jpashop혹은jdbc:h2:file:~/jpashop과 같은 설정을 사용해 보세요.
- 휘발성 메모리 데이터베이스를 사용하고 있다면, 같은 연결 세션이 아니면 데이터가 유지되지 않을 수 있습니다.
아래는 유사한 문제를 가진 다른 질문 링크입니다. 참고하시어 문제를 해결해 보세요:
이 외에도 SQL 쿼리 로그가 남지 않는 경우가 있다면, show_sql 설정을 활성화하여 실제 쿼리가 어떻게 실행되는지 확인하는 것도 도움이 될 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
27
1
sdk 설정 오류
0
65
2
오탈자 - @Transactional
0
62
1
src/test/resources 테스트 경로 문제
0
56
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
70
1
MemberRepositoryTest 실행오류
0
90
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
195
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
153
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
56
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
80
1
기본 생성자
0
67
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
106
1
멤버서비스테스트 부분에서 막힙니다.
0
173
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
124
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
128
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
121
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
114
2
빌드 툴, Gradle
0
63
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
81
2
Repository에서 EntityManager 주입 방식 차이
0
97
1
롬복과 사용자 정의 setter 메서드
0
77
1
주문 목록 조회 fetch join 질문드립니다
0
91
1
dirty checking 질문드립니다.
0
86
1





