CoreData 数据库更新,数据迁移

一般程序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.sqliteURl路径

    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吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值