如果使用 sorm,如何处理架构更改

Posted

技术标签:

【中文标题】如果使用 sorm,如何处理架构更改【英文标题】:how to handle schema change if using sorm 【发布时间】:2015-01-31 15:03:06 【问题描述】:

我是 OR 映射技术的新手。我想知道我是否使用 SORM 将数据持久化到 DB,如何处理未来的数据库架构更改?

例如, 这是用户类: case class User(name:String, age:Int)

如果将来我想再添加一个字段,例如性别,该怎么办? 我是否需要手动更改现有表,或者 SORM 是否可以帮助我做到这一点 新字段的默认值是多少 如果我想添加一个非空字段怎么办?

或者使用 SORM 更改数据模式并不容易?这似乎很受限制。处理数据库架构更改的最佳方法是什么?

【问题讨论】:

【参考方案1】:

实施迁移。让您的原始模型和更新的模型连接到关联的数据库,并使用它们将所有数据从原始模型迁移到新模型。之后您可以删除原始数据库。

您可以将其实现为脚本或某种形式的迁移策略解析函数。例如,您可以有一个包含当前架构版本信息的表,您可以使用它来确定如何将数据库迁移到当前版本。

当然,它不会像手动 SQL 更改那样快,但它是所有 ORM 的折衷方案。

【讨论】:

以上是关于如果使用 sorm,如何处理架构更改的主要内容,如果未能解决你的问题,请参考以下文章

AWS postgres RDS 读取复制如何处理架构切换?

如何处理派生类的多个重载而不需要对其他文件进行多次更改

清洁架构 - 如何处理数据库事务?

AWS Glue:如何处理具有不同架构的嵌套 JSON

微服务架构中的分布式事务,如何处理超时和失败的提交

微服务架构的分布式事务问题如何处理?