zoukankan      html  css  js  c++  java
  • 关于Core Data的一些整理(四)

    关于Core Data的一些整理(四)

    • 调用Core Data文件中的Request模板进行条件匹配

    1 //获取ObjectModel相当于获取Core Date文件
    2   NSManagedObjectModel *model = self.coreDataStack.contenxt.persistentStoreCoordinator.managedObjectModel;
    3   self.fetchRequest = [model fetchRequestTemplateForName:@"FetchRequest"];
    4   self.venues = [self.coreDataStack.contenxt executeFetchRequest:self.fetchRequest error:nil];
    • iOS8新增Asynchronous异步调用Core Data,提高性能
     1 @property (nonatomic, strong) NSFetchRequest *fetchRequest;
     2 @property (nonatomic, strong) NSAsynchronousFetchRequest *asyncFetchRequest;
     3 
     4   //asyncFetch只是对普通request的封装
     5   self.fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Venue"];
     6   self.asyncFetchRequest = [[NSAsynchronousFetchRequest alloc] initWithFetchRequest:self.fetchRequest completionBlock:^(NSAsynchronousFetchResult * _Nonnull result) {
     7     self.venues = result.finalResult;
     8     [self.tableView reloadData];
     9   }];
    10   //注意调用的是executeRequest:方法
    11   [self.coreDataStack.contenxt executeRequest:self.asyncFetchRequest error:nil];
    • iOS8新增批(Batch)处理,链接

    Batch Updates或Batch Deletes与普通NSFetchRequest请求不同的是,他们都基于NSPersistentStoreRequest类,这是直接对底层的NSPersistentStore进行数据操作的请求,而不经过NSManagedObjectContext,因此避免将固态存储的数据转移到内存再处理的过程,因此效率大大提升。

    1 //设置批处理请求,包含更新的内容,影响的stores
    2   NSBatchUpdateRequest *batchUpdate = [NSBatchUpdateRequest batchUpdateRequestWithEntityName:@"Venue"];
    3   batchUpdate.propertiesToUpdate = @{@"favorite":@YES};
    4   batchUpdate.affectedStores = self.coreDataStack.contenxt.persistentStoreCoordinator.persistentStores;
    5   batchUpdate.resultType = NSUpdatedObjectsCountResultType;//返回更新的行数
    6   
    7   NSBatchUpdateResult *batchResult = [self.coreDataStack.contenxt executeRequest:batchUpdate error:nil];
    8   NSLog(@"%@", batchResult.result);
    9   //在iOS9中又新增
  • 相关阅读:
    leetcode
    Eclipse出现"Running Android Lint has encountered a problem"解决方式
    乱码又来捣乱了
    给MySQL增加一个表示例
    给MySQL中某表增加一个新字段,设为主键值为自动增长。
    MySQL数据源在Spring中的配置
    DB2数据源在Spring环境中的配置
    为何你变成了“焦”“郁”“碌(怒)”
    十一有感
    将来的你 一定会感谢 现在努力拼搏奋斗的自己
  • 原文地址:https://www.cnblogs.com/jackma86/p/5131355.html
Copyright © 2011-2022 走看看