3

我有一个 Spring Boot 应用程序并想使用 Liquibase 为我的 JPA 实体生成更改日志。但是,根据我的方法,我会遇到不同的问题。

  • 我的第一种方法是使用 Maven 插件的diff目标。url 是我的带有 H2 驱动程序的 H2 开发数据库,​​参考 URL 类似于带有驱动程序“ liquibase.ext.hibernate.database.connection ”的“ hibernate:spring:myBasePackage.myEntityPackage?dialect=org.hibernate.dialect.H2Dialect ” .HibernateDriver ”。在这种情况下,Liquibase 似乎可以识别我的实体,但会将差异打印到控制台。此外,差异没有变更日志文件的形式。
  • 我的第二种方法是使用 maven 插件的generateChangeLog目标。在这种情况下,我的 url 是“ hibernate:spring:myBasePackage.myEntityPackage?dialect=org.hibernate.dialect.H2Dialect ”,驱动程序为“ liquibase.ext.hibernate.database.connection.HibernateDriver。在这种情况下,我收到一个错误”无法解析持久性单元根 URL:类路径资源 [] 无法解析为 URL,因为它不存在”。这个错误可以在 Spring 和 Liquibase 问题跟踪器中找到,但似乎总是这样说错误已经修复。
  • 我的第三种方法基本上与第二种方法类似,但在这种情况下,我使用了一个带有“ CustomClassicConfigurationFactory ”实现的“ hibernate:classic ”url ,它显式地注册了我的注释类。这确实有效。但是,在这种情况下,我必须在我的 application-jar 中执行此操作。我必须将我的 application-jar 添加为 maven-plugin 的依赖项。因此,在生成更改日志之前,我必须构建我的 application-jar(并将其安装到本地 Maven 存储库)。这似乎很麻烦。

我的问题是:

  • 有没有一种更简单的方法可以在基于 Spring 引导的应用程序中为 JPA 实体生成更改日志?
  • 为什么前两种方法不起作用?
  • 有没有办法简化第三种方法?

我在用:

  • Spring Boot 1.5.4.RELEASE
  • Liquibase-Hibernate4 3.6
  • Liquibase 3.5.3

提前谢谢了。

4

1 回答 1

0

在使用 的第一种方法中liquibase:diff,不会生成实体的更改集(创建表更改集),因为liquibase不假定新jpa实体为更改。

在第二种方法generateChangeLog中,它从给定的数据库生成更改日志。它不会查看您的jpa实体。

为了为您的 jpa 实体生成 ddl 脚本,只需将以下内容提交到您的 jpa 属性

<property key="javax.persistence.schema-generation.scripts.action">drop-and-create</property>
<property key="javax.persistence.schema-generation.scripts.create-target">./ddl/create.sql</property>
<property key="javax.persistence.schema-generation.scripts.drop-target">./ddl/drop.sql</property>  

以上将在根文件夹下的ddl文件夹中生成脚本。

您可以在此处查看其他属性https://thoughts-on-java.org/standardized-schema-generation-data-loading-jpa-2-1/

于 2019-04-02T12:05:08.040 回答