首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Liquibase验证异常: mysql中不允许forIndexName

Liquibase验证异常: mysql中不允许forIndexName
EN

Stack Overflow用户
提问于 2019-12-10 08:05:31
回答 1查看 1.4K关注 0票数 0

我已经从现有的oracle数据库中生成了变更集。当我试图在MYSQL数据库中执行更改集以复制模式时,我会得到以下异常:

代码语言:javascript
复制
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'liquibase' defined in class path resource [org/springframework/boot/autoconfigure/liquibase/LiquibaseAutoConfiguration$LiquibaseConfiguration.class]: Invocation of init method failed; nested exception is liquibase.exception.ValidationFailedException: Validation Failed:
     1 changes have validation failures
          forIndexName is not allowed on mysql, db/changelog/2019/001-initial_schema.xml::157562123123-12::sahilmehta97 (generated)

失败的改变是

代码语言:javascript
复制
<changeSet author="sahilmehta97 (generated)" id="157562123123-11">
        <createIndex indexName="STUDENTID_UNIQUE" tableName="STUDENT" unique="true">
            <column name="STUDENT_ID"/>
        </createIndex>
</changeSet>
<changeSet author="sahilmehta97 (generated)" id="157562123123-12">
        <addUniqueConstraint columnNames="STUDENT_ID" constraintName="STUDENTID_UNIQUE" forIndexName="STUDENTID_UNIQUE" tableName="STUDENT"/>
    </changeSet>

我知道MYSQL不支持forIndexName,但是它是使用mvn :generateChangeLog命令自动生成的。那么,我应该做什么来克服这个问题呢?

是否有任何方法可以从oracle database?

  • Should中生成与MYSQL兼容的变更集?我对从oracle数据库生成的更改集进行了更改吗?
  1. 有什么方法可以使生成的chageset与MYSQL兼容,当我运行mvn液化基: update命令来更新MYSQL数据库??

或者还有别的办法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-11 22:09:17

从数据库生成的变更量不能保证在不同的数据库平台上工作。尽管Liquibase XML changelog格式被设计为与数据库无关的格式,但仍然有一些特定于数据库的特性。

如果您的目标是创建一个适用于多个数据库平台的changelog,则必须进行特殊的注意(和测试),以确保changelog与这些平台一起工作。描述所有必须做的不同的事情是非常困难的。

在本例中,我将修改变更集,以便从变更集中移除forIndexName属性。然后使用液化基update命令对其进行测试,将变更集部署到Oracle和MySQL数据库,以确保它正在做您想做的事情。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59262702

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档