Java FlywayException:无法扫描位置:classpath:db/migration中的SQL迁移
我试图开始使用flyway与maven集成,但无法使其工作 我遵循的文件似乎是非常简单的,所以没有奇怪的事情似乎要做 Mypom.xml如下所示:Java FlywayException:无法扫描位置:classpath:db/migration中的SQL迁移,java,database,maven,flyway,Java,Database,Maven,Flyway,我试图开始使用flyway与maven集成,但无法使其工作 我遵循的文件似乎是非常简单的,所以没有奇怪的事情似乎要做 Mypom.xml如下所示: <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.a
<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>
<groupId>com.test</groupId>
<artifactId>test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<build>
<plugins>
<!-- Flyway plugin configuration -->
<plugin>
<groupId>org.flywaydb</groupId>
<artifactId>flyway-maven-plugin</artifactId>
<version>3.0</version>
<configuration>
<url>jdbc:mysql://localhost:3306/test</url>
<user>test_fede</user>
<password>test_fede</password>
</configuration>
<dependencies>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.21</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>13.0.1</version>
</dependency>
<!-- DB dependencies -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.21</version>
</dependency>
<!-- Test dependencies -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.8.1</version>
<scope>compile</scope>
</dependency>
</dependencies>
</project>
能帮我一下吗
太多了。好吧,让你知道 我发现了问题,它发生在我们在环境中设置flyway时,但我们没有任何要执行的迁移 它不应该显示类路径错误,但幸运的是它正在工作 顺便说一下,我发现的另一个问题是,在执行init后,如果我们使用info进行检查,则不会显示任何内容。如果我们使用V1添加一个新迁移,那么info将不会显示它,除非我们将其更改为V1
希望对您有所帮助如果在调用flyway:migrate之前未执行编译目标,也会发生这种情况。实际上,这包含在快速启动手册中。它说: mvn编译飞道:迁移
但是,如果您忽略了这个细节,开始调用mvn flyway:migrate,SQL文件将不会被复制到目标目录中(实际上目标目录甚至不存在),您将得到这个神秘的错误。我遇到了同样的问题。在我的例子中,我的迁移脚本位于导致问题的错误目录中。我将脚本V1\uuu Create\u person\u table.sql移动到了resources/db/migration/的正确目录中,它成功了 我也面临同样的问题。但当我仔细查看日志时,我发现flywaydb正在db/migration文件夹中查找脚本,但我的脚本在db/migrate中。因此,在更正了从db/migrate到db/migration的路径之后,它就可以工作了 我犯了一个愚蠢的错误,我犯了这个讨厌的错误:
确保在pom.xml中将打包设置为
jar
而不是pom
。然后mvn安装
,确保M2文件夹中有该项目的jar,否则会出现此错误,因为迁移文件未被复制并找到。我也有类似问题。在我的例子中,我认为在对所有内容进行了三次检查之后,我已经正确地命名了目录。结果是我输入了migrations
,而不是migration
。我一把它修好,一切都很好
在此之前,我在迁移文件名中的版本标记(V1)之后遇到了另一个下划线问题。它需要是一个dunder(双下划线),所以它总是V1\uu description.sql
似乎我遇到的所有飞行路线问题都不是一团糟。它总是一些小东西,可以很容易地修复。这只是为了找出问题所在。这是最困难的部分。我遇到了类似的问题,这是因为当我创建迁移目录时,我直接给它命名为
db.migration
通过创建目录
db
,然后在其中创建迁移
目录,它工作。这可能是因为如果输入目录为空,maven没有创建输出目录。附言:你可能不需要初始化。这仅适用于现有数据库。对于新用户,迁移就足够了。请检查我的答案希望它会有帮助,检查这是否可能有帮助:
$ mvn compile flyway:info
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Building Unnamed - com.test:test:jar:0.0.1-SNAPSHOT
[INFO] task-segment: [compile, flyway:info]
[INFO] ------------------------------------------------------------------------
[INFO] [resources:resources {execution: default-resources}]
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 0 resource
[INFO] [compiler:compile {execution: default-compile}]
[INFO] Nothing to compile - all classes are up to date
[INFO] [flyway:info {execution: default-cli}]
[INFO] Database: jdbc:mysql://localhost:3306/test (MySQL 5.5)
[INFO] ------------------------------------------------------------------------
[ERROR] BUILD ERROR
[INFO] ------------------------------------------------------------------------
[INFO] org.flywaydb.core.api.FlywayException: Unable to scan for SQL migrations in location: classpath:db/migration
Embedded error: Unable to determine URL for classpath location: db/migration (ClassLoader: org.codehaus.classworlds.RealmClassLoader@5bcdbf6)
[INFO] ------------------------------------------------------------------------
[INFO] For more information, run Maven with the -e switch
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1 second
[INFO] Finished at: Tue May 06 11:06:15 CST 2014
[INFO] Final Memory: 17M/223M
[INFO] ------------------------------------------------------------------------