我正在解析大量数据,我最初将其插入到核心数据存储中.
稍后,我正在解析相同的XML,尽管其中一些可能已经更新.然后我做的是检查具有相同标签的现有记录,如果已经存在,我用数据更新记录.
然而,虽然我的初始解析(约11.000条记录)需要8秒左右,但更新似乎很昂贵,需要144秒(这些是模拟器运行,因此在实际设备上显着更长).
虽然第一次很好(我正在显示进度条),但第二次是不可接受的长,我想做一些事情来提高速度(即使它发生在一个单独的线程的后台).
不幸的是,这不是find-or-create的问题,因为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]; }
解决方法
不要进行大量的提取,而是对每个实体类型进行一次查询,并按标记将它们存储在字典中,然后只检查字典是否存在具有该键的对象.您应该能够将propertiesToFetch设置为仅包含标记,并且应该减少开销.