我正在使用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] 举报,一经查实,本站将立刻删除。