테스트 시 테이블 생성 방법
697
3 câu hỏi đã được viết
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)
[질문 내용]
테스트시 테이블 초기 생성 질문드립니다.
강의에서는 테스트 테이블 세팅을 위해 /test/resources/schema.sql 파일을 생성하고 내부에 DDL을 작성하여서 테이블을 생성해주었는데요.
이 방법은 엔티티가 많아질 수록 DDL이 많아져서 관리하기에 어려움이 있을 것 같다는 생각이 듭니다.
그래서 test의 application.properties 내부에 spring.jpa.hibernate.ddl-auto=create 설정을 주어 테이블 생성과 validation을 위임하는 것이 좋지 않을까 하는 생각이 있는데, 어떻게 생각하시는지 궁금합니다.
Câu trả lời 2
2
그렇군요. JPA에 종속적인 방식이라는 단점이 있겠네요.
생각을 해보니 JPA환경에서 schema.sql파일과 spring.jpa.hibernate.ddl-auto=create을 둘 다 설정하면 어떤 설정이 우선시 되어 가져가 질 지 궁금증이 생기네요.
한번 테스트 해봐야 할 것 같습니다.
감사합니다.
0
schema.sql와 ddl-auto를 같이 사용하면 오류가 발생하네요.
하이버네이트는 따로 내부 실행 스크립트가 존재하기 때문에 하이버네이트에서 한번 schema.sql에서 한번 돌려 중복 입력 오류가 발생하는 것으로 파악하였습니다.
그래서 스프링 프로필에 따라 설정를 바꿔줄 수있는지 뒤져보니 properties 파일에 spring.sql.init.mode을 none으로 주면 schema.sql과 data.sql등 스크립트를 무시하게 할 수 있습니다.
결론은 둘다 사용은 불가능하고 spring.jpa.hibernate.ddl-auto=create로 주는 경우 initMode를 none으로 하여 중복입력을 막고 jpa를 사용안하는 경우나 ddl-auto를 validate로 사용하는 경우는 initMode를 사용해주면 될것 같네요.
참고 글.
https://www.baeldung.com/spring-boot-data-sql-and-schema-sql
https://pravusid.kr/java/2018/10/10/spring-database-initialization.html
RepositoryTest의 패키지 위치가 domain인 이유
0
15
1
REQUIRES_NEW 해결 방법에 대해서 질문있습니다!!
0
25
1
update()에 사용하는 setter 질문드립니다.
0
43
1
SQL 중심적 개발의 문제점에 대한 질문
0
70
1
혹시 Containing 을 안쓰신 이유가 있을까요?
0
80
2
[공유] 스프링부트 4.x 버전 mybatis 연동
0
170
1
@repository 어노테이션
0
88
3
ItemService
0
56
1
논리 커밋, 물리 커밋 질문드립니다.
0
52
1
내부 트랜잭션 커밋은 필수인가요?
0
55
1
프록시 커넥션 객체를 반환할 때 생성하는건가요?
0
52
1
Transaction readOnly 성능 개선 (김영한님의 대한 감사인사)
2
176
2
JPQL 대신 네이티브 쿼리를 사용해야 하는 경우
0
76
1
@EventListener(ApplicationReadyEvent.class) 관련
0
87
1
트랜잭션 동기화 매니저와 데이터 소스
0
74
1
DB 관련 강의 개설 계획은 없으신건가요?
0
132
2
물리 트랜잭션 과 논리트랜잭션 용어를 맞게 이해한걸까요
0
92
1
스프링 3 버전 이상 rollbackFor 변경된듯요
1
109
1
트랜잭션 전파 질문.
0
86
1
프로젝트 오픈 에러
0
124
1
외부 트랜잭션에서 isNewTransaction이 false로 나오는거에 대해 질문드립니다
0
82
2
같은 스레드를 사용하면 트랜잭션 동기화 매니저는 같은 커넥션을 반환
0
70
1
h2 인메모리 테스트중 예약어 충돌날 경우 대처방법
0
99
1
커스텀aop와 트랜잭션을 같이 사용할때 우선순위에 관한 질문
0
94
2

