# 애플리케이션 실행 시 초기 DB 스크립트를 실행하는 방법
1. sql 파일 생성
- 경로 : /src/main/resources 경로 하위
- schema.sql : 테이블 생성 스크립트
- data.sql : 데이터 입력 스크립트
- 파일이름규칙 : schema-${platform}.sql , data-${platform}.sql
ex. schema-h2.sql , shcema-postgres.sql
2. application 실행 시 스크립트 자동 실행됨
[참고 - 스프링 공식 문서]
17.9.3. Initialize a Database Using Basic SQL Scripts
Spring Boot can automatically create the schema (DDL scripts) of your JDBC DataSource or R2DBC ConnectionFactory and initialize it (DML scripts). It loads SQL from the standard root classpath locations: schema.sql and data.sql, respectively. In addition, Spring Boot processes the schema-${platform}.sql and data-${platform}.sql files (if present), where platform is the value of spring.sql.init.platform. This allows you to switch to database-specific scripts if necessary. For example, you might choose to set it to the vendor name of the database (hsqldb, h2, oracle, mysql, postgresql, and so on). By default, SQL database initialization is only performed when using an embedded in-memory database. To always initialize an SQL database, irrespective of its type, set spring.sql.init.mode to always. Similarly, to disable initialization, set spring.sql.init.mode to never. By default, Spring Boot enables the fail-fast feature of its script-based database initializer. This means that, if the scripts cause exceptions, the application fails to start. You can tune that behavior by setting spring.sql.init.continue-on-error.
Script-based DataSource initialization is performed, by default, before any JPA EntityManagerFactory beans are created. schema.sql can be used to create the schema for JPA-managed entities and data.sql can be used to populate it. While we do not recommend using multiple data source initialization technologies, if you want script-based DataSource initialization to be able to build upon the schema creation performed by Hibernate, set spring.jpa.defer-datasource-initialization to true. This will defer data source initialization until after any EntityManagerFactory beans have been created and initialized. schema.sql can then be used to make additions to any schema creation performed by Hibernate and data.sql can be used to populate it.
If you are using a Higher-level Database Migration Tool, like Flyway or Liquibase, you should use them alone to create and initialize the schema. Using the basic schema.sql and data.sql scripts alongside Flyway or Liquibase is not recommended and support will be removed in a future release.
'개발 > Spring' 카테고리의 다른 글
[Spring] @Transactional 핵심 정리 / 우선순위, 프록시, 예외 (0) | 2022.11.26 |
---|---|
[Springboot] 라이브러리 의존성 버전 확인 및 선택하는 방법! dependency version (0) | 2022.03.31 |
[Spring Validation] BindingResult 오류메시지 추가 / properties 파일 / 샘플 코드 (0) | 2022.02.20 |
[Spring Security] 요청 권한 설정 / HttpMethod, url 패턴으로 접근 권한 관리 (0) | 2022.01.21 |
[Springboot] DB migration Tool / Flyway 설정 방법 (0) | 2022.01.19 |
댓글