【发布时间】:2012-07-11 23:50:10
【问题描述】:
我正在尝试设置我的应用程序,以便在部署到任何环境时自动升级数据库,因此我在 Spring 配置中添加了以下内容:
<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@${db.host}:${db.port}:${db.database}" />
<property name="username" value="${db.username}" />
<property name="password" value="${db.password}" />
<property name="maxActive" value="4" />
<property name="maxWait" value="5000" />
<property name="defaultAutoCommit" value="false" />
<property name="defaultReadOnly" value="false" />
<property name="validationQuery" value="select '1' from DUAL" />
</bean>
<!-- ADDED IN AN ATTEMPT TO FIX THE PROBLEM -->
<bean id="flyway-init" class="com.googlecode.flyway.core.Flyway" init-method="init">
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="flyway" class="com.googlecode.flyway.core.Flyway" init-method="migrate" depends-on="flyway-init">
<property name="dataSource" ref="datasource"/>
</bean>
但是当我在 JBoss 7 中运行它时,出现以下错误:
com.googlecode.flyway.core.validation.ValidationException: Found non-empty schema 'WMYERS' without metadata table! Use init() first to initialize the metadata table.
我已经对数据库运行了一个 flyway clean-migrate,所以它已经设置好并准备好了,并且存在 SCHEMA_HISTORY 表,有什么想法吗?
【问题讨论】:
-
原来以前的开发人员出于某种奇怪的原因为 init 表指定了一个不同的名称....一旦我删除了它,一切都很好!