一、通过配置
需要配置项目下的yml文件:
在文件下加如如下配置:
data: classpath:
initialization-mode: always
-mode:
初始化模式(springboot2.0),其中有三个值:
always为始终执行初始化
embedded只初始化内存数据库(默认值),如h2等
never为不执行初始化
:
数据初始化,默认加载,还会加载data-${platform}.sql文件,也可以指定文件,一般放在resources文件夹下,然后使用classpath:文件.sql
指定 DQL(数据查询)脚本或DML(数据操作)脚本 文件, 一般都是数据插入脚本文件
yml:
spring:
datasource:
driver-class-name:
url: jdbc:postgresql://localhost:5432/are_code_generator
username: postgres
password: 123456
data: classpath:
initialization-mode: always
# url: jdbc:mysql://192.168.70.38:4307/are_oms_tankInfo?useUnicode=true&characterEncoding=utf-8&useSSL=false
# username: root
# password: 123456
jackson:
time-zone: GMT+8
jpa:
properties:
open-in-view: true
hibernate:
show_sql: true
format_sql: true
dialect:
temp:
use_jdbc_metadata_defaults: false
hbm2ddl:
auto: update
database: postgresql
rabbitmq:
host: 192.168.90.230
port: 5672
username: vxsip
password: vxsip
virtual-host: /
service:
employee:
staff: http://192.168.90.230/msc/are-basic/v1/sys/organization/staffs
moudleAccountUrl: http://192.168.90.230/msc/are-basic/v1/login/account
二、通过代码加载sql
首先将sql文件放在根目录下,将文件加载:
@Value("classpath:create_table.sql")
private Resource createTableSql;
重写数据源初始化方法:
@Bean
public DataSourceInitializer dataSourceInitializer(final @Qualifier("forwardDataSource") DataSource dataSource) {
DataSourceInitializer dataSourceInitializer = new DataSourceInitializer();
(dataSource);
(databasePopulator());
return dataSourceInitializer;
}
private DatabasePopulator databasePopulator() {
ResourceDatabasePopulator populate = new ResourceDatabasePopulator();
(createTableSql);
return populate;
}