获取FlywayException:SP2-0310:无法打开文件-当sqlpus @与文件路径一起使用时 - java

我正在使用启用了oracleSqlplus的flyway pro。我创建了一个文件夹结构来组织基于对象的脚本。尝试在flyway版本脚本中使用@(带有路径),该脚本不起作用。

文件夹结构,

topFolder
-folderA
-AScript.sql
-folderB
-BScript.sql
-folderCommon
-AScript.sql
-V1__ASCRIPT.sql
-V2__BSCRIPT.sql
-V3__ASCRIPT.sql

内容:
V1__ASCRIPT.sql
@ AScript.sql->正确执行topFolder / folderA / Ascript.sql的文件
V2__BScript.sql
@ BScript.sql->正确执行topFolder / folderB / Bscript.sql的文件
V3__ASCRIPT.sql
@ topFolder / folderCommon / AScript.sql->这使我跌破错误,
org.flywaydb.core.api.FlywayException:SP2-0310:无法打开文件“ topFolder / folderCommon / AScript.sql”

我尝试了几乎所有可能的组合,
绝对路径
与“ @ .. / .. / topFolder / folderCommon / AScript.sql”
尝试设置SQLPATH变量
与@@
这没有用。
仅在@中给出文件名即可。但我想指定路径,以便可以重复使用文件名,并且不易出错。

我希望相对路径应该与flyway + oraclesqlplus选项一起使用。

提前致谢。

参考方案

好像您从fly flyway.locations=filesystem:结束的点开始的路径就是您的路径的开始。
例:

flyway.locations=filesystem:/opt/app/sql

您的脚本在哪里/opt/app/sql/appadb/script.sql

里面的母版将是
@@appadb/script.sql

java:继承 - java

有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…

Java-如何将此字符串转换为日期? - java

我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…

JAVA 8具有任何匹配属性的对象的过滤器列表 - java

我的要求是通过匹配任何属性的字符串来过滤对象列表。例如,假设Contact类具有三个属性:街道,城市,电话。我知道java流过滤器是如何工作的,在这里我必须将输入字符串与每个属性进行比较,如下所示:contactList.stream().filter(contact -> contact.getStreet().equals("dubai&…

Java-固定大小的列表与指定初始容量的列表之间的差异 - java

我在理解这一点上遇到了问题。当我们做 List<Integer> list = Arrays.asList(array); 我们不能在该列表上使用添加,删除之类的方法。我知道Arrays.asList()返回固定大小的列表。我不明白的是,如果我们创建一个具有指定初始容量的列表,例如List<Integer> list2 = new A…

从方法返回数组-Java - java

private static Coordinate[] getCircleCoordintaes() { Coordinate coordinates[] = {new Coordinate(0, 0)}; return coordinates; } 以上程序工作正常。在上面的程序中,返回的坐标数组首先初始化了数组使用这条线Coordinate coordi…