在Spring XML Config文件中从其他子项目加载sql脚本

时间:2018-08-06 16:15:44

标签: xml spring maven gradle classpath

在这个Spring项目中,我有几个子项目可以用作微服务。 在每个子项目中,我都尝试集中化重复的SQL测试脚本。

当前文件结构如下。

|rootproject
|--- microservice1
|     └─src
|       └─test
|         └─resources
|            ├─spring-config.xml
|            └─sql
|               └─h2
|                  ├─somescript.sql
|                  └─somescript2.sql
|--- microservice2
|--- microservice3

所有这些微服务基本上都与微服务1共享相同的文件结构。

是否可以创建另一个子项目以包含sql脚本,而不是使用重复的sql测试脚本?像这样的东西。

|rootproject
|--- testdata
|     └─src
|       └─test
|         └─resources
|            ├─spring-config.xml
|            └─sql
|               └─one
|               |  └─h2
|               |     └─bunchOfScripts.sql
|               └─two
|                  └─h2
|                     └─bunchOfScripts.sql
|--- microservice1
|--- microservice2
|--- microservice3

我目前在每个子项目/微服务的spring-config.xml文件中都有一个Bean,它初始化一个Bean以读取下面显示的h2数据。

<bean id="someID" class="package.to.load.data" init-method="load">
   <constructor-arg value="classpath:/sql/h2" />
</bean>

如何指定类路径以在其他子项目中调用sql脚本?在这种情况下,请调用文件夹testdata中的测试脚本。

1 个答案:

答案 0 :(得分:0)

假设Maven,您只需要使testdata子项目成为其他子项目的依赖项即可。这样会将testdata子项目放置在其他项目的类路径中,并且您对通过classpath:URI的条目的现有引用应该起作用。 (即使您的testdata子项目中没有任何Java代码,您可能也必须将其标记为Java项目,以便它做正确的事?)。

有两个问题:您必须将资源文件放在src / main中,而不是src / test中,因为Maven不会将src / test导出到其他项目中-但您可以随后添加对testdata作为测试依赖项,因此它将仅在测试期间查看/使用。并且您可能需要修改文件夹设置,或将脚本移动到src / test / resources(因为这是Maven Java项目期望找到它们的位置)。