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

박세준님의 프로필 이미지
박세준

작성한 질문수

스프링 DB 2편 - 데이터 접근 활용 기술

테스트 - 스프링 부트와 임베디드 모드

테스트 시 테이블 생성 방법

작성

·

541

1

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예)

[질문 내용]
테스트시 테이블 초기 생성 질문드립니다.

강의에서는 테스트 테이블 세팅을 위해 /test/resources/schema.sql 파일을 생성하고 내부에 DDL을 작성하여서 테이블을 생성해주었는데요.
이 방법은 엔티티가 많아질 수록 DDL이 많아져서 관리하기에 어려움이 있을 것 같다는 생각이 듭니다.

그래서 test의 application.properties 내부에 spring.jpa.hibernate.ddl-auto=create 설정을 주어 테이블 생성과 validation을 위임하는 것이 좋지 않을까 하는 생각이 있는데, 어떻게 생각하시는지 궁금합니다.

답변 2

2

박세준님의 프로필 이미지
박세준
질문자

그렇군요. JPA에 종속적인 방식이라는 단점이 있겠네요.

생각을 해보니 JPA환경에서 schema.sql파일과 spring.jpa.hibernate.ddl-auto=create을 둘 다 설정하면 어떤 설정이 우선시 되어 가져가 질 지 궁금증이 생기네요.

한번 테스트 해봐야 할 것 같습니다.

감사합니다.

박세준님의 프로필 이미지
박세준
질문자

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

2

안녕하세요. 박세준님, 공식 서포터즈 OMG입니다.
.

DB접근기술이 JPA가 아닐 때(Mybatis, JDBC template 등)에서도 해당 옵션이 동작할까요?

JPA 환경에서만 적용가능한 옵션인지 확인해보시면 좋을 것 같아요 !
.
감사합니다.

박세준님의 프로필 이미지
박세준

작성한 질문수

질문하기