3

我想使用 Flyway 来迁移数据库。在 Grails (Spring) 应用程序中,可以简单地定义一个自定义 bean 并根据该 bean 标记 Hibernate SessionFactory。

flyway(Flyway) { bean ->
    bean.initMethod = 'migrate'
    dataSource = ref('dataSource')
    locations = 'classpath:migration/db/mysql'
    baselineOnMigrate = true
    table = 'schema_version'
}

if (springConfig.containsBean('hibernateDatastore')) {

    BeanDefinition beanToInlineWithFlyway = getBeanDefinition('hibernateDatastore')

    def dependsOnList = ['flyway'] as Set
    if (beanToInlineWithFlyway.dependsOn?.length > 0) {
        dependsOnList.addAll(beanToInlineWithFlyway.dependsOn)
    }
    beanToInlineWithFlyway.dependsOn = dependsOnList as String[]
}

Micronaut 有没有办法实现同样的目标?

我喜欢这样做的原因是:

使用 Flyway 进行数据库迁移时,您将所有 DDL 内容委托给 Flyway 并将 Hibernate 设置jpa.default.properties.hibernate.hbm2dll.autovalidate.

jpa:
  default:
    properties:
      hibernate:
        hbm2ddl:
          auto: validate

Flyway 将在 Hibernate 之前启动,并检查是否需要迁移数据库表。之后,Hibernate 启动并根据当前 JPA 实体验证数据库模式。

4

1 回答 1

3

与其依赖易碎的 bean 名称,不如定义一个实现BeanCreatedEventListener<DataSource>. 这将在DataSource创建 bean 之后但在创建之前运行SessionFactory

于 2018-10-15T13:18:56.427 回答