CoreData 数据库更新,数据迁移
2016-05-23 11:14
381 查看
本文转载至 http://blog.163.com/djx421@126/blog/static/48855136201411381212985/
一般程序app升级时,数据库有可能发生改变,如增加表字段,增加表等。 此时有两种操作:第一种就是毫无留情的把本地旧数据库直接删掉,重新建立新的数据库;
第二种就是数据库迁移,更新数据库。
第一种情况是简单粗暴型,但不会保留任何历史数据,一般不推荐使用。
这里主要介绍第二种情况,分四步操作:
第一步,上代码,主要红色字体的地方
- (NSPersistentStoreCoordinator *)persistentStoreCoordinator
{
if (_persistentStoreCoordinator != nil) {
return _persistentStoreCoordinator;
}
NSFileManager *fileManager = [NSFileManager defaultManager];
NSString *folderPath = [NSString stringWithFormat:@"%@/Calendar",[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask, YES) lastObject]];
if(![fileManager fileExistsAtPath:folderPath]){//如果不存在,则说明是第一次运行这个程序,那么建立这个文件夹
[fileManager createDirectoryAtPath:folderPathwithIntermediateDirectories:YES attributes:nil error:nil];
}
NSURL *storeURL = [NSURL fileURLWithPath:[folderPathstringByAppendingPathComponent:@"Calendar.sqlite"]];
NSDictionary *options = [NSDictionary dictionaryWithObjectsAndKeys:
[NSNumber numberWithBool:YES],
NSMigratePersistentStoresAutomaticallyOption,
[NSNumber numberWithBool:YES],
NSInferMappingModelAutomaticallyOption, nil];
NSError *error = nil;
_persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:[self managedObjectModel]];
if (![_persistentStoreCoordinatoraddPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURLoptions:options error:&error]) {
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
return _persistentStoreCoordinator;
}
第二步:增加一个新版本的数据模型
选择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 上直接修改表结构,再添加新版本,这样的话会一直报错)
PS:NSURL *storeURL = [NSURL fileURLWithPath:[folderPath stringByAppendingPathComponent:@"Calendar.sqlite"]]; 这里还是Calendar.sqlite,而不是Calendar 2.sqlite,因为在第三步中已经选择了Calendar 2。
ok,开始build吧
相关文章推荐
- xtrabackup如何备份mysql数据库
- mysql导入导出sql文件
- wamp下安装phpredis扩展
- spark读取redis数据(交互式,scala单机版,java单机版)
- Padding Oracle Attack的一些细节与实现
- SBT编译spark-redis-master
- MongoDB基础之一:Conetos下安装MongoDB
- Better PostgreSQL datacenter schema
- mysql索引总结----mysql 索引类型以及创建
- 数据库概论
- Oracle 11g 透明网关连接mssql2008r2数据库
- mysql 性能优化的几点建议
- java redis代码配置
- memcached 分布式实现原理
- java redis相关操作类
- 重写代码生成器支持模板(多层架构,MVC),多语言c#,java;支持mysql和sqlserver,动态编译
- oracle11g安装和学习bbed(转载)
- SQL Server 的最大容量规范
- 看mysql的like是否使用索引
- MongoDB基础之五:游标