zoukankan      html  css  js  c++  java
  • CoreData 数据库更新,数据迁移

    本文转载至 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吧

  • 相关阅读:
    【shell】两种字符串提取场景的实现
    【batch】批处理文件多参数处理和for循环字符串连接
    【Java】「深入理解Java虚拟机」学习笔记(4)- 类文件结构
    【Java】「深入理解Java虚拟机」学习笔记(2)- JVM内存区域
    【Java】「深入理解Java虚拟机」学习笔记(1)
    【Myeclipse】用Myeclipse10.5搭建C/C++开发环境
    【JDK】JDK模块化(1)-为什么要模块化
    【DOS】文件统计命令
    【java】转:Windows系统下面多个jdk版本切换
    【Web】servlet、filter和listener
  • 原文地址:https://www.cnblogs.com/Camier-myNiuer/p/5519241.html
Copyright © 2011-2022 走看看