微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – Liquibase为postgres创建Schema

我正在使用Dropwizard(1.0.0)和Liquibase创建一个数据库(如果它不存在).

这里的问题是我使用的是不同的Postgres模式(不公开).看起来Liquibase以前不能创建这个架构了吗?我期待Liquibase生成这个模式,但如果我尝试构建数据库,它总是会抛出“找不到名称xx的模式”.

最佳答案:

尽管Liquibase在其捆绑的更改/重构中没有CREATE SCHEMA(因此在dropwizard数据库转储期间不会生成一个),但您仍然可以使用sql tag将其作为变更集包含在迁移更改日志中,如下所示:

<changeSet author="christian" id="1">
    <sql dbms="postgresql" endDelimiter=";">
        CREATE SCHEMA foo
    </sql>
</changeSet>

请注意,在应用任何更改集之前,Liquibase将在PUBLIC架构中创建自己的表:
如果你在dropwizard中运行db migrate –dry-run,你会看到Liquibase首先执行

CREATE TABLE PUBLIC.DATABASECHANGELOGLOCK ...
CREATE TABLE PUBLIC.DATABASECHANGELOG ...

在跑步之前

CREATE SCHEMA foo;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐