首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >核心数据模型更改后如何从备份恢复SQLite数据库(轻量级迁移)

核心数据模型更改后如何从备份恢复SQLite数据库(轻量级迁移)
EN

Stack Overflow用户
提问于 2012-09-13 08:32:51
回答 2查看 905关注 0票数 4

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

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

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

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-01-20 20:29:38

如果您打开包含核心数据的sqlite数据库,则轻量级迁移会自动发生。主要作为应用程序更新的一部分,但也可以在打开恢复的数据库时使用。

您可以添加一个检查,以查看在恢复后是否需要迁移:

代码语言:javascript
运行
复制
-(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
EN

Stack Overflow用户

发布于 2012-09-13 12:14:02

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

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12397877

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档