如何在Core Data模型更改后从备份还原SQLite数据库(轻量级迁移)

时间:2012-09-13 00:32:51

标签: iphone sqlite core-data migration restore

我有一个核心数据应用程序,它将其sqlite数据库备份到Dropbox,用户可以通过在需要时覆盖当前数据库来恢复它。

在下一个应用程序版本中,核心数据模型已更改,现有用户的数据库将通过轻量级迁移过程自动更新。

我关注的是已经备份的数据库。如果用户去恢复在迁移之前备份的sqlite数据库,它将与最新的模型不匹配,它将使应用程序崩溃。

有没有办法在恢复过程中更新数据库,以匹配我的核心数据模型?我可以运行的流程,还是我可以采取的一些步骤,以确保备份不会丢失?

2 个答案:

答案 0 :(得分:1)

如果使用核心数据打开sqlite数据库,则会自动进行轻量级迁移。主要是作为应用程序更新的一部分,也是在打开已还原的数据库时。

您可以添加一项检查,以确定恢复后是否需要迁移:

-(BOOL) storeRequiresMigration: (NSURL *) storeURL {
NSError *error = nil;
NSPersistentStoreCoordinator * temporaryPersistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];

//Check if migration is needed
NSDictionary *sourceMetadata = [NSPersistentStoreCoordinator metadataForPersistentStoreOfType:NSSQLiteStoreType URL:storeURL error:&error];
NSManagedObjectModel *destinationModel = [temporaryPersistentStoreCoordinator managedObjectModel];
BOOL isCompatibile = [destinationModel isConfiguration:nil compatibleWithStoreMetadata:sourceMetadata];
NSLog(@"Store requires migration: %d", !isCompatibile);
return !isCompatibile;

}

答案 1 :(得分:0)

只要您在应用中保留以前的数据模型版本,轻量级迁移就应该为您处理此过程。从您的问题来看,我相信这正是轻量级迁移所需要的。它推断了以前数据模型版本的变化,并将旧数据映射到新数据模型

在您希望在数据模型中重命名某些内容的特殊情况下,您可以使用位于“版本控制”下的检查器中的重命名ID来执行此操作。