我有一个核心数据应用程序,可以将其sqlite数据库备份到Dropbox,用户可以在需要时通过覆盖当前数据库来恢复它。
在下一个应用程序版本中,核心数据模型发生了变化,现有用户的数据库将通过轻量级迁移过程自动更新。
我关心的是已经备份的数据库。如果用户要恢复迁移前备份的sqlite数据库,它将与最新的模型不匹配,并且会使应用程序崩溃。
有没有什么方法可以在恢复过程中更新数据库,以匹配我的核心数据模型?要么是我可以运行的进程,要么是我可以采取的一些步骤来确保备份不会丢失?
发布于 2014-01-20 20:29:38
如果您打开包含核心数据的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;}
发布于 2012-09-13 12:14:02
只要您在应用程序中保留以前的数据模型版本,轻量级迁移就会为您处理此过程。从你的问题来看,我相信这正是轻量级迁移所要解决的问题。它从以前的数据模型版本中推断出更改,并将旧数据映射到新数据模型中
在特殊情况下,您希望重命名数据模型中的某些内容,您可以使用位于检查器中"Versioning“下的重命名ID来执行此操作。
https://stackoverflow.com/questions/12397877
复制相似问题