iOS应用数据存取之数据库存储-----Core Data

给你一囗甜甜゛ 提交于 2019-12-04 12:52:13

iOS应用数据存取的常用方式有如下几种 XML属性列表 —— PList NSKeyedArchiver 归档 Preference(偏好设置) SQLite3 Core Data

现在我想记录以下我对core Data的认识 存在理由:苹果公司为了关照不会使用SQL数据库的程序员,而产生的,面向对象操作数据库的oc语言 Core Data简介: Core Data 是iOS SDK 里的一个很强大的框架,允许程序员以面向对象的方式储存和管理数据。使用Core Data框架,程序员可以很轻松有效地通过面向对象的接口管理数据 Core Data框架提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite3数据库文件中,也能够将保存在数据库中的数据还原成OC对象 在数据操作过程中,无需编写任何SQL语句 要使用Core Data,需要导入CoreData框架

NSPersistentStoreCoordinator的产生: 为了让模型对象和数据库能够连接起来,苹果公司就创建了NSPersistentStoreCoordinator这个对象,用来作为他们之间的桥梁! [NSManagedObjectModel mergedModelFromBundles:nil];合并所有的图形化定义的Mode--------------》[[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model]:建立持久化存储调度---------------> addPersistentStoreWithType:指定数据库文件保存的路径,如果有,直接打开,如果没有,新建在打开---------------> _sharedContext.persistentStoreCoordinator = store;获得数据库操作句柄

具体使用如下 // 1. 实例化持久化的存储 // 1.1 从Bundle中加载被管理的数据模型 NSManagedObjectModel *model = [NSManagedObjectModel mergedModelFromBundles:nil]; // 1.2 实例化持久化存储调度 NSPersistentStoreCoordinator *store = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model]; ... // 1.3 添加持久化存储(SQLite)- [store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:url options:nil error:&error]; ...---------------这里我们是不是可以添加持久化存储为sql数据库呢????? // 管理对象上下文 _context = [[NSManagedObjectContext alloc] init]; _context.persistentStoreCoordinator = store;

NSEntityDescription insertNewObjectForEntityForName 实体(数据库的表)的描述(最开始建立数据模型时指定的实体) 实体描述,用于描述个人信息的一个对象 Context,统一负责数据库的操作 实例: Person *p = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:_context]; p.name = @"张三"; p.age = @18; [_context save:nil];

执行查询之后

  1. Sections属性中记录了分组情况,如果没有指定分组,则是所有对象! Sections对象遵守了NSFetchedResultsSectionInfo协议!
  2. 使用objectAtIndexPath可以直接取出查询的结果。
  3. 设置查询结果控制器的代理方法,并且实现 controllerDidChangeContent:(NSFetchedResultsController *)controller 代理方法,可以在数据库内容发生变化时,重新刷新表格即可 所有数据变化,尽在掌控!

查询数据——NSFetchedResultsController NSManagedObjectContext *context = [[DataManager sharedDataManager] sharedContext]; NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Person"]; // 定义查询排序 NSSortDescriptor *sort = [NSSortDescriptor sortDescriptorWithKey:@"name" ascending:YES]; request.sortDescriptors = @[sort]; // 定义查询结果控制器 _fetchedResultController = [[NSFetchedResultsController alloc] initWithFetchRequest:request managedObjectContext:context sectionNameKeyPath:nil cacheName:nil]; [_fetchedResultController performFetch:&error];

NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Person"]; request.predicate = [NSPredicate predicateWithFormat:@"%K LIKE '52' OR name CONTAINS '三'", @"phoneNo"]; NSArray *array = [_context executeFetchRequest:request error:nil];


最后,在开发中要注意 如果开发过程中,修改了数据模型,简单的办法就是将沙盒中的数据库直接删除! 否则运行会崩溃!

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!