Find centralized, trusted content and collaborate around the technologies you use most.
Teams
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
我是 OR-mapping 技术的新手。我想知道我是否使用 SORM 将数据持久化到 DB,如何处理未来的数据库架构更改?
例如,这里是 User 类: case class User(name:String, age:Int)
如果将来我想再添加一个字段,例如性别,我需要手动更改现有表吗,或者 SORM 是否可以帮助我执行此操作?新字段的默认值是什么?如果我想添加一个非空字段怎么办? ?
或者使用 SORM 更改数据模式并不容易?这似乎很受限制。处理数据库模式更改的最佳方法是什么?
实施迁移。让您的原始模型和更新的模型连接到关联的数据库,并使用它们将所有数据从原始模型迁移到新模型。之后您可以删除原始数据库。
您可以将其实现为脚本或某种形式的迁移策略解析函数。例如,您可以有一个包含当前模式版本信息的表,您可以使用它来确定如何将数据库迁移到当前版本。
当然,它不会像手动 SQL 更改那么快,但它是所有 ORM 的折衷方案。