对于使用像db4o这样的对象数据库,我一直觉得很困惑的一件事是,您应该如何处理通常由 SQL/PL-SQL 处理的复杂迁移。
例如,假设您在关系数据库中有一个名为 my_users 的表。最初您有一个名为“full_name”的列,现在您的软件处于 V2 中,您希望删除此列,将全名拆分为空白并将第一部分放在名为“first_name”的列中,第二部分放在列中名为姓氏。在 SQL 中,我将简单地填充“first_name”和“second_name”列,然后删除名为“full_name”的原始列。
我将如何在 db4o 之类的东西中做到这一点?我是否编写了一个 Java 程序,该程序通过脚本查找 User.class 的所有对象,在设置 first_name 和 last_name 时将 full_name 设置为 null?当我进行下一次 svn 提交时,将没有与 full_name 对应的字段/bean-property,这会是一个问题吗?似乎在我的“模式”发生更改的生产应用程序中使用它我想编写一个脚本来将数据从版本 x 迁移到版本 x+1,然后在版本 x+2 中实际删除我正在尝试的属性摆脱版本 x+1,因为我无法编写 Java 脚本来修改不再属于我的类型的属性。
似乎问题的一部分是RDBMS根据简单的不区分大小写的基于字符串的名称解析您所指的对象,在Java之类的语言中,打字比这更复杂,如果getter不能引用属性/setter/field 不是在运行时加载的类的成员,因此您基本上需要在同一个脚本中拥有 2 个版本的代码(嗯,自定义类加载器听起来很痛苦),存储您的类的新版本属于另一个包(听起来很乱),或者使用我提到的版本 x+1 x+2 策略(需要更多计划)。也许有一些我从未从 db4o 文档中收集到的明显解决方案。
有任何想法吗?希望这有点道理。