到目前为止,我已经将 liquibase 与 spring 和标准变更日志文件一起使用。现在我想将其集成到 hibernate 中,因此当我对实体进行任何更改时,它应该更改表并更新更改日志表。
我阅读了很多示例和教程,但无法使其工作。
我使用数据源,entityManagerFactory(denepds-on="liquibase") 一切正常。但是当我添加 liquibase bean 时,它不会从实体更改数据库。并且抛出“没有名称的表”异常。
如何使用 liquibase-hibernate4 和 spring 配置 Liquibase?
我的 liquibase bean :
<bean id="liquibase" class="liquibase.integration.spring.SpringLiquibase">
<property name="dataSource" ref="myJdbcDataSource" />
<property name="beanName" value="entityManagerFactory" />
<property name="changeLog" value="classpath:databaseChangeLog.sql" />
</bean>
我刚刚从: https://github.com/liquibase/liquibase-hibernate/wiki 添加了 beanName 属性作为entityManagerFactory , http://www.liquibase.org/documentation/spring.html 。并做了我从这篇文章中可以理解的事情。
在这篇文章中,它提到我们应该使用三种变体之一
hibernate:spring:com/example/spring.xml?bean=sessionFactory
hibernate:spring:com.example?dialect=org.hibernate.dialect.MySQL5Dialect
hibernate:spring:com.example.employee,com.example.auction?dialect=org.hibernate.dialect.MySQL5Dialect
但是当我们使用spring时,我不知道如何将它与liquibase bean一起使用
最佳答案
我使用 Spring、Liquibase 和 Hibernate 已有多年,我不建议您随心所欲地使用它。我的经验告诉我,让 Hibernate 自动更改数据库并不是一个好主意。
我不介意该更改是由 hibernate 使用 hbm2ddl 计算的,还是通过 liquibase 计算的,liquibase 最终计算来自 hibernate 的数据库更改。您宁愿先监督这些更改,然后再将其合并到您的更改日志中。
所以,就我而言,我更喜欢配置 liquibase (使用 Maven)来自动写入通过比较我的 hibernate 映射与数据库而获得的更改日志(我称之为 autochangelog)。然后我手动检查变更集,然后将其与我的变更日志合并。
当然,您可以使用 SpringLiquibase bean 在每次启动应用程序时自动运行 liquibase 更新,这是开箱即用的,但在不同环境下工作时要小心,您可能会运行不需要的更新...
也许您可以找到您感兴趣的这篇文章http://malaguna.github.io/blog/2015/06/09/liquifying-your-project/
这里描述了我如何使用 Spring、Hibernate 和 Liquibase,就像我告诉你的那样。
关于java - 无法通过 Spring Hibernate 获得 Liquibase 工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34705683/