提高更新Core Data中现有记录(~11000)的速度

run*_*mad 7 core-data nsfetchrequest ios

我正在解析大量数据,我最初将其插入到核心数据存储中.

稍后,我正在解析相同的XML,尽管其中一些可能已经更新.然后我做的是检查具有相同标签的现有记录,如果已经存在,我用数据更新记录.

然而,虽然我的初始解析(约11.000条记录)需要8秒左右,但更新似乎很昂贵,需要144秒(这些是模拟器运行,因此在实际设备上显着更长).

虽然第一次很好(我正在显示一个进度条),但第二次是不可接受的长,我想做一些事情来提高速度(即使它发生在一个单独的线程的后台).

不幸的是,这不是查找或创建的问题,因为XML中的数据可能已针对单个记录进行了更改,因此每个人都可能需要更新.

我对属性进行了索引,这加快了初始解析和更新,但它仍然很慢(上面的数字是索引).我注意到解析/更新似乎逐渐减慢.虽然最初速度很快,但随着越来越多的记录被处理,它会越来越慢.

所以最后我的问题是,如果我有什么建议可以提高我更新数据集的速度?我正在使用MagicalRecord获取记录.这是代码:

Record *record;
if (!isUpdate) {
    record = [NSEntityDescription insertNewObjectForEntityForName:@"Record" inManagedObjectContext:backgroundContext];
} else {
    NSPredicate *recordPredicate = [NSPredicate predicateWithFormat:@"SELF.tag == %@", [[node attributeForName:@"tag"] stringValue]];
    record = [Record findFirstWithPredicate:recordPredicate];
}
Run Code Online (Sandbox Code Playgroud)

Sen*_*ior 3

不要进行大量的获取,而是对每种实体类型进行一次查询,并按标签将它们存储在字典中,然后只需检查字典是否存在具有该键的对象。您应该能够将propertiesToFetch 设置为仅包含标记,并且它应该减少开销。