我的应用程序有以下场景:
对于数据库迁移,我们使用Hibernate Schema Update For the Schema和DBUnit来填充所有生产数据(在所有服务器/计算机上)。当模式更新完成后,我为新模式生成一个新的DTD文件,这样我就可以重新导入DBUnitXML。应用程序在启动时使用XML文件更新数据库(仅在开发和测试服务器/计算机上!)
当然,这种方法不是最佳和脆弱的。所以我看了利基贝斯和飞行路线。两者似乎都是很好的工具,但我没有得到的是:如何迁移数据?在我的情况下,我每周转储一次生产系统的数据,并将其作为DBUnit XML文件添加到应用程序源代码管理中,因此所有开发人员都有“新鲜”数据,测试服务器也有当前的生产数据。
我看到的Liquibase和Flyway的问题是,没有解决方案如何从数据库数据进行自动差异,并自动生成迁移更改。
所以我的想法是以下步骤:
另一个想法是利用flyways Java迁移并提供基于DBUnit的初始数据库转储。数据库数据的所有其他更改都将在迁移脚本中处理。但仍然存在问题:如何使当前迁移脚本状态和生产数据库状态不同?
如果有人能为我提供如何处理我的场景的提示,那就太棒了:)
简而言之,你所有的改变都将通过Liquibase或Flyway来完成。
我们使用Flyway,具有相同的prod/test/开发设置。我们使用Flyway迁移脚本进行所有数据库更改(结构或元数据),并存储在源代码控制中。每次我们对环境进行新部署时,我们首先在那里运行迁移脚本(使用命令行工具或maven插件)。代码首先进入开发环境,在那里进行集成测试,并继续进行测试和生产。
需要注意的主要问题是,Flyway需要对文件进行线性版本控制,因此,如果两个开发人员同时签入迁移,则其中一个开发人员将不得不重命名他们的迁移。
如果您的目标是在DEV和TEST环境中使用PROD数据库的转储,我会:
这样,当PROD数据库恢复到DEV或TEST时,迁移工具的旧元数据表也会恢复。
当应用程序启动时,迁移工具会发现db结构已过时并将其升级到最新版本。完成。
无需为此使用数据库单位。
我们仍处于项目的早期阶段,我们正在构建一个包含多个表的数据库。列出的两个工具都允许我们创建一些DDL / DML文件并跟踪对数据库的更改。无论如何,当结构仍未合并时,这可能会很麻烦。 假设我想添加一个新列,甚至删除一个表:在这两个程序中,我都必须使用ALTER TABLE/etc.命令创建一个新脚本并记录更改。 在terraform中,您只需编写所需的基础设施,当您通过删除节点来更改文件时,该工具
PHPSSO 数据库结构[更新日期:2010-12-28] 点击查看 PHPCMS 数据库结构[更新日期:2010-12-28] 点击查看
如果我在changelogs中的某个点从liquibase结果的mysql转储中进行重建,那么重建将会最快,而我之前忽略了changelogs。因此,我将删除changelog master中的所有内容,除了我的master build dump changelog之外,这将是整个数据库,出于版本控制的原因,我保留了实际的changelog。 在LiquiBase中有没有合适的/指定的/安全的方法
问题内容: 从Actor中读取的文件:Zac Efron 传记:他出生于加利福尼亚州的圣路易斯·奥比斯波,并在阿罗约·格兰德附近长大。在几集《夏姆兰》(2004)的客串中,他以女孩疯狂的卡梅隆·贝尔的身份参加常规演出。埃夫隆还出演过许多飞行员,例如卡尔·兰克(Carl Laemke)的《大世界》(2003)(电视)和三重播放(2004)(TV)。 More_Bio:Efron于2006年6月毕业于
利用INSERT语句将数据插入表中 数据插入 用来插入(添加)行到数据库。 插入完整的行 插入行的一部分 插入某些查询结果 插入完整的行 指定表名和被插入到新行中的值 编写依赖与特定列次序的SQL语句,这样做有时会出错,但编写方便。 mysql> INSERT INTO Customers -> VALUES('1000000006', -> 'Toy Land', ->
问题内容: 我对ES非常陌生。我一直在尝试搜索数据库迁移工具,但找不到。我想知道是否有人可以帮助我指出正确的方向。 我将使用Elasticsearch作为项目中的主要数据存储。我想对我在项目中开发新模块时运行的所有映射和配置更改/数据导入/数据升级脚本进行版本控制。 过去,我使用过数据库版本控制工具,例如Flyway或Liquibase。 我可以在ES中使用任何框架/脚本或方法来实现类似目的吗?