我们正在考虑将 flyway 集成到我们的系统中,因为它似乎是一种以有效方式管理数据库迁移的好工具。
但是,我不太确定如何进行:
我们有三个不同的数据库
- 生产环境(MySQL)
- 测试环境(MySQL)
- 单元测试(H2 内存)
它们都包含不同的数据(不同的用户等)。数据库之间没有共同的数据(在flyway页面上这称为参考数据),只有结构应该保持不变。
看看网站,我的理解是这样进行的:
我们必须从生产环境中提取模式版本并将其保存在 V1__BASE_version.sql 等文件中。我会这样做,例如:
mysqldump -d -u 用户名 -p 密码 -h 主机名 dbname
我们通过获取结构的转储并将其与生产系统中的结构进行比较来确保 ddl 与测试环境的匹配(从差异开始,然后在不清楚的地方手动进行)。万一我们发现任何差异,我们通过更改用于测试或实时的 db 结构来摆脱它们(取决于更有意义的方式)。
我们使用主页描述的初始版本的数据初始化所有数据库。对于我不同的数据库,我使用不同的 -Durl=、-Dusername= 和 -Dpassword= 参数。
mvn flyway:init -Dflyway.initVersion=1 -Dflyway.initDescription="基础版本"
配置我们的弹簧设置以拾取飞行路线(如主页所述)。这可确保自动应用迁移,并且数据库与应用程序处于一致状态
这是正确的方法吗?我是否忘记了任何重要步骤?
我还有一个关于将测试数据添加到内存数据库的问题:
插入单元测试数据的正确位置在哪里?即使我使用 spring 设置 flyway 并使休眠依赖于它使用
<bean id="sessionFactory" class="..." depends-on="flyway">
...
</bean>
数据源将在之前创建,目前这是我们添加架构和测试数据的地方。如果我们在创建数据源时仍然添加示例数据,那么如果我没记错的话,架构将不是正确的。
我们如何使用内存数据库将测试数据与 flyway 一起使用?
谢谢!