集成框架 -- 项目启动时创建mysql数据库结构

前言

项目中要使用一些数据库,默认数据。所以需要做一些初始化操作

正文

配置Spring JDBC的DataSource初始化

如果您要执行自定义路径下的SQL文件,可以通过配置Spring JDBC的DataSource初始化去执行特定路径下的SQL文件:


@Configuration
public class DataSourceConfig {

    @Bean
    public DataSourceInitializer dataSourceInitializer(DataSource dataSource) {
        DataSourceInitializer initializer = new DataSourceInitializer();
        initializer.setDataSource(dataSource);
        initializer.setDatabasePopulator(databasePopulator());
        return initializer;
    }

    private DatabasePopulator databasePopulator() {
        ResourceDatabasePopulator populator = new ResourceDatabasePopulator();
        populator.addScript(new ClassPathResource("database/xxxx.sql"));
        return populator;
    }
}

确保将reformer.sql文件放至src/main/resources/database/目录下。

application.properties

spring.datasource.schema=classpath*:database/xxxx.sql

application.yml

spring:
  datasource:
    schema: classpath*:database/xxxx.sql

这告诉Spring Boot去执行启动时指定的SQL脚本。

使用 data.sql 进行数据库初始化

使用 data.sql 进行数据库初始化,找到资源文件夹 src/main/resources/。在该文件夹内创建一个名为 data.sql 的新文件。

vim src/main/resources/data.sql
INSERT INTO my_table (id, name, description) VALUES (1, 'Name 1', 'Description 1');
INSERT INTO my_table (id, name, description) VALUES (2, 'Name 2', 'Description 2');

application.properties

spring.datasource.initialization-mode=always

application.yml

spring:
  datasource:
    initialization-mode: always

确保没有使用JPA的DDL Auto功能,如果您使用了Spring Data JPA,那么可能会有一个 ddl-auto 设置,它可以影响数据库的初始化。默认当使用内嵌数据库时,ddl-auto 设置为 create-drop.

但对于非内嵌数据库,默认为 none。所以,如果您需要Spring Boot执行 data.sql

application.properties


spring.jpa.hibernate.ddl-auto=none

或者:

application.yml

spring:
  jpa:
    hibernate:
      ddl-auto: none

上述配置表示不使用Hibernate的DDL自动生成特性。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值