一般程序app升级 或者 数据库发生改变,如增加表字段,增加表等。
有两种操作:
- (NSPersistentStoreCoordinator *)persistentStoreCoordinator {
if (_persistentStoreCoordinator != nil) {
return _persistentStoreCoordinator;
}
//数据迁移或者更新
NSDictionary *options = [NSDictionary dictionaryWithObjectsAndKeys:
[NSNumber numberWithBool:YES],
NSMigratePersistentStoresAutomaticallyOption, //自动迁移版本存储
[NSNumber numberWithBool:YES],
NSInferMappingModelAutomaticallyOption, nil]; //协调员将试图推断出一个映射模型
// 初始化对象
_persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
//获得CoreData.sqlite的URl路径
NSURL *storeURL = [[self applicationDocumentsDirectory] URLByAppendingPathComponent:@"CoreData.sqlite"];
NSError *error = nil;
//加载数据库和创建数据库
if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:options error:&error]) {
//abort()导致应用产生崩溃日志和终止。在开发过程中,不应该使用此功能,虽然在开发过程中可能是有用的。
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
return _persistentStoreCoordinator;
}
注:此时修改数据库 addPersistentStoreWithType 就不会报错或者崩溃
当版本升级保留原来的数据 需要数据迁移:如下步骤
第二步:增加一个新版本的数据模型
选择Calendar.xcdatamodel文件 点击Editor -> Add Model Version 弹出一个对话框,填写Version Name (如 Calendar 2) 和Based on model (如 Calendar)。
第三步:继续选择Calendar.xcdatamodel文件 ,按option + command + 0 键,打开xcode最右侧栏, 在model version 的Current 中选择Calendar 2.
第四步:修改你的Calendar 2.xcdatamodel文件(如新增字段,添加表等操作),然后记得更新你改动表的entity代码。(注:这个步骤顺序一定要注意,千万不能在原Calendar.xcdatamodeld 上直接修改表结构,再添加新版本,这样的话会一直报错)
注意:NSURL *storeURL = [NSURL fileURLWithPath:[folderPath stringByAppendingPathComponent:@"Calendar.sqlite"]]; 这里还是Calendar.sqlite,而不是Calendar 2.sqlite,因为在第三步中已经选择了Calendar 2。
ok,开始build吧