Java Spring启动数据初始化自定义路径
我有一个spring boot应用程序。我希望像下面的结构一样将数据初始化文件保存在包本身中Java Spring启动数据初始化自定义路径,java,spring-boot,Java,Spring Boot,我有一个spring boot应用程序。我希望像下面的结构一样将数据初始化文件保存在包本身中 something.com.package1 --model.class --service.class --controller.class --mydata.sql something.com.package2 --model.class --service.class --controller.class --mydata2.sql 在spring.datasou
something.com.package1
--model.class
--service.class
--controller.class
--mydata.sql
something.com.package2
--model.class
--service.class
--controller.class
--mydata2.sql
在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将其作为spring boot应用程序运行时,它运行良好
但是,如果我使用mnv clean package
构建一个jar,并使用java-jar app.jar
运行,则不会读取文件
pom.xml
<?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>
4.0.0
org.springframework.boot
spring启动程序父级
2.1.4.1发布
诺华公司
伊多
0.0.1-快照
伊多
Idot应用程序
1.8
org.springframework.boot
spring引导启动器数据jpa
org.springframework.boot
SpringBootStarterWeb
org.springframework.boot
弹簧靴开发工具
运行时
mysql
mysql连接器java
运行时
org.springframework.boot
弹簧起动试验
测试
org.springframework.boot
springbootmaven插件
我怎样才能达到同样的效果
编辑:
如果文件作为
data.sql
保存在/src/main/resources
中,那么运行jar和从eclipse运行时,它可以正常工作,但我希望将每个模型的数据保存在它的包中。我也知道我可以使用liquibase
或flywaydb
,但为什么它在这种情况下不起作用 通常流行数据源的init.sql和data.sql位于resources文件夹(src/main/resources)中,该文件夹在启动时自动执行
如果要使用schema.sql,应设置:
spring.jpa.hibernate.ddl-auto=none
通常,常用数据源的init.sql和data.sql位于resources文件夹(src/main/resources)中,该文件夹在启动时自动执行 如果要使用schema.sql,应设置:
spring.jpa.hibernate.ddl-auto=none
我知道,如果它是src/main/resources的一部分,它将被自动拾取,但我想进行其他配置。我既不想使用schema.sqlI知道,如果它是src/main/resources的一部分,它将被自动拾取,但我想进行其他配置。我也不想使用schema.sqlShow来显示POM。您正在使用maven资源插件吗?它需要定制以从src/main/java.Show您的POM获取资源。您正在使用maven资源插件吗?它需要定制以从src/main/java获取资源。