我有一个春季启动应用程序。我想将数据初始化文件保存在包本身中,如下面的结构。
something.com.package1
--model.class
--service.class
--controller.class
--mydata.sql
something.com.package2
--model.class
--service.class
--controller.class
--mydata2.sql
我可以在classpath
application.properties中使用spring.datasource.data
实现相同的目标
spring.jpa.hibernate.ddl-auto=create
spring.datasource.initialization-mode=always
spring.datasource.data=classpath:com/idot/userAccessForm/*.sql
spring.datasource.url=jdbc:mysql://localhost:3306/xx
spring.datasource.username=xx
spring.datasource.password=xx
当我尝试从eclipse运行它作为一个春季启动应用程序,它工作正常
但是,如果我使用mnv clean package
构建一个jar并使用java -jar app.jar
运行,则不会读取文件。
pom.hml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.novartis</groupId>
<artifactId>idot</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>idot</name>
<description>Idot App</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
我怎样才能实现同样的目标?
编辑:
如果文件作为/src/main/resources
保存在data.sql
中,它可以很好地运行jar并从eclipse运行但是我想保留每个模型的数据在它的包本身。我也明白我可以使用liquibase
或flywaydb
,但为什么它不适用于这种情况?
通常,流行数据源的init.sql和data.sql驻留在资源文件夹(src / main / resources)中,该文件夹在启动时自动执行。
如果要使用schema.sql,则应设置:
spring.jpa.hibernate.ddl-auto=none