我有一个Spring Boot应用程序。我想将数据初始化文件保留在包中,如下所示。
something.com.package1
--model.class
--service.class
--controller.class
--mydata.sql
something.com.package2
--model.class
--service.class
--controller.class
--mydata2.sql
我可以使用classpath
中的spring.datasource.data
实现相同的功能
application.properties
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>
我怎么能达到同样的目的?
编辑:
如果文件以/src/main/resources
的形式保存在data.sql
中,则可以很好地运行jar和从eclipse运行,但是我想将每个模型的数据保留在包本身中。我也知道我可以使用liquibase
或flywaydb
,但是为什么在这种情况下它不起作用?
答案 0 :(得分:0)
通常,流行数据源的init.sql和data.sql驻留在资源文件夹(src / main / resources)中,该文件夹在启动时自动执行。
如果要使用schema.sql,则应设置:
@IBAction func selectRoutineButtonPressed(_ sender: Any) {
let fetchRequest: NSFetchRequest<Workout> = Workout.fetchRequest()
do {
let workouts = try PersistenceService.context.fetch(fetchRequest)
self.routines = workouts
} catch {}
DispatchQueue.main.async {
self.exerciseTableView.reloadData() // Not Working
}
if exerciseTableView.isHidden == true {
animate(toggle: true, togglingTableView: exerciseTableView)
}
else {
animate(toggle: false, togglingTableView: exerciseTableView)
}
}