在编写用于创建表的changeSet时,可以指定表的模式(请参见here)
如果我运行
liquibase generateChangeLog输出不包括架构。
作为参考,下面是我使用的liquibase.properties文件:
driver: org.h2.Driver
classpath: h2-1.4.181.jar
url: jdbc:h2:~/test.db
username: sa
password: sa
changeLogFile: baseline.xml
liquibaseCatalogName: LIQUIBASE
liquibaseSchemaName: BAR
defaultSchemaName: BAR
outputDefaultSchema: true
outputDefaultCatalog: true其中一个表的输出:
<createTable tableName="PRODUCTS">
<column name="ID" type="INT(10)"/>
<column name="CODE" type="VARCHAR(10)"/>
<column name="PRICE" type="DECIMAL(9, 2)"/>
</createTable>如果我要手动编写这段代码,我会包含模式:
<createTable schemaName="BAR" tableName="PRODUCTS">
<column name="ID" type="INT(10)"/>
<column name="CODE" type="VARCHAR(10)"/>
<column name="PRICE" type="DECIMAL(9, 2)"/>
</createTable>这是设计出来的吗?事后我可以使用XSLT。
发布于 2014-10-23 04:19:38
在generateChangeLog之后使用--includeCatalog=true标志。例如:liquibase generateChangeLog --includeCatalog=true
只有当generateChangeLog应该首先包含模式信息时,才使用outputDefaultSchema。
发布于 2018-12-19 18:57:14
请使用outputDefaultSchema=true。这将输出变更集中的架构名称。使用maven插件时,请使用<outputDefaultSchema>true</outputDefaultSchema>
https://stackoverflow.com/questions/26308533
复制相似问题