迁移的关键是要做几件事:首先,在没有当前备份的情况下不要做任何事情。其次,如果密钥将要更改,则需要至少临时将新旧结构都存储在新结构中(如果用户将密钥字段暴露给用户,则永久存在,因为他们可能正在搜索密钥字段以获取旧记录)。
接下来,您需要对与子表的关系有透彻的了解。如果更改键字段,则所有相关表也必须更改。这是同时存储新旧密钥的地方。如果您忘记更改其中任何一个,则数据将不再正确且将无用。因此,这是关键的一步。
挑选出一些特别复杂的数据的测试用例,以确保为每个相关表包括一个或多个测试用例。将现有值存储在工作表中。
要开始迁移,请使用旧表中的选择插入新表中。根据记录的数量,您可能希望遍历批处理(一次不一次记录)以提高性能。如果新密钥是一个标识,则只需将旧密钥的值放在其字段中,然后让数据库创建新密钥。
然后对相关表执行相同操作。然后,使用表中的旧键值将外键字段更新为:
Update t2set fkfield = newkeyfrom table2 t2join table1 t1 on t1.oldkey = t2.fkfield
通过运行测试用例,并将数据与迁移之前存储的数据进行比较,以测试迁移。彻底测试迁移数据绝对至关重要,否则您将无法确定数据是否与旧结构保持一致。迁移是一个非常复杂的动作。花费时间并非常有条理和彻底地做到这一点是值得的。



