CoreData
之前在学习使用SQLite时, 需要编写大量的sql语句,完成数据的增删改查,但对于不熟悉sql语句的开发人员来说,难度较大,调试程序比较困难。
由此出现CoreData框架,将sql的操作转换成为对象的操作,无需编写sql语句。并且对数据库的操作也可以可视化。
1. CoreData 自iOS5出现的框架,提供了对象-关系映射(ORM)功能。通过此框架可将 对象 转化成数据,存储到SQLite 数据库文件中,
也能将SQLite数据库中的数据转化成对象。CoreData实际上是封装了的SQLite操作的库,封装度高,无需开发人员接触SQL语句。
在CoreData中,需要被映射的对象被称为实体(entity),即sqlite中的表;每个实体都有属性,即sqlite中对应表的字段。
> 使用CoreData
— 先创建模型文件(相当于创建数据库表结构),后缀名 xcdatamodeld
两种方式创建:
a. 可以在创建iOS 工程时,选择 use Core Data, 工程中会自动生成模型文件
b. 创建工程后 New file ,选择iOS ->Core Data -> Data Model
— 添加实体,(添加表)
Add Entity 注意:实体名字首字母大写
— 给实体添加属性 (在表中添加字段)
Attributes -> + 注意:实体属性名字首字母小写
— 如何通过代码访问
先了解CoreData 中的核心对象
1.) Managed Object Model 管理的对象模型
描述应用程序的数据模型,这个模型包含实体(Entity),属性(Property),读取请求(Fetch Request)等。 对应代码中的类:NSManagedObject ,类似于NSDictionary , 通过键-值存取实体属性。
2.)Managed Object Context 管理的对象上下文
参与对数据对象进行各种操作的全过程,并监测数据对象的变化,以提供对 undo/redo 的支持及更新绑定到数据的 UI。
3.)Persistent Store Coordinator 持久化存储协调者
相当于数据文件管理器,处理底层的对数据文件的读取与写入。一般我们无需与它打交道。
4. )Managed Object 管理的对象
数据对象,与 Managed Object Context 相关联。
— 代码访问步骤:
1. )初始化NSManagedObjectModel对象,加载模型文件,读取app中的所有实体信息
2. )初始化NSPersistentStoreCoordinator对象,添加持久化库(这里采取SQLite数据库)
3. )初始化NSManagedObjectContext对象,拿到这个上下文对象操作实体,进行增删改查(CRUD)操作
代码如下:
// 获取应用程序资源束下的数据实体
NSManagedObjectModel *model = [NSManagedObjectModel mergedModelFromBundles:nil];
// 以获取的实体初始化持久化存储的协调者(中间桥梁)
NSPersistentStoreCoordinator *psc = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];
// 在指定目录下创建持久化存储,基于sqlite类型
NSString *docs = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
NSURL *url = [NSURL fileURLWithPath:[docs stringByAppendingPathComponent:@"my.db"]];
NSError *err = nil;
NSPersistentStore *store = [psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:url options:nil error:&err];
// 若创建持久化存储失败,则抛出异常
if (store == nil) {
NSLog(@"error");
[NSException raise:@"error" format:@"%@",[err localizedDescription]];
}
// 创建数据操作的上下文,并指定其持久化存储的协调者
context = [[NSManagedObjectContext alloc] init];
context.persistentStoreCoordinator = psc;
— 将Core Data中的 实体 与 代码中的 数据模型 对应
Core Data中的实体都是NSManagedObject类型的。
创建继承自NSManagedObject的子类
New file->iOS->Core Data-> NSManagedObject
这样在代码中可通过 favorite.NewsId 来访问实体属性,而不是之前的 [nsManagedObject setValue: forKey:], [nsManagedObject valueForKey:];
-- 增,删,改,查
增: // 先以数据实体为原型生成一个实体对象
Favorite *fr = [NSEntityDescription insertNewObjectForEntityForName:@"Favorite" inManagedObjectContext:context];
// 赋值操作
// 通过上下文保存此次增加
[context save:&err];
删:// 先初始化抓取数据的请求,指定其抓取何种类型的实体对象
[[NSFetchRequest alloc] initWithEntityName:@"Favorite"];
// 指定其筛选数据的条件
request.predicate = [NSPredicate predicateWithFormat:@"newsId = %@",@(objId)];
// 执行抓取请求
[context executeFetchRequest:request error:nil];
// 删除找到的数据
[context deleteObject:obj];
// 务必通过上下文同步到数据存储
[context save:&err];
改: // 先初始化抓取数据的请求,指定其抓取何种类型的实体对象
[[NSFetchRequest alloc] initWithEntityName:@"Favorite"];
// 指定其筛选数据的条件
request.predicate = [NSPredicate predicateWithFormat:@"newsId = %@",@(objId)];
// 执行抓取请求
[context executeFetchRequest:request error:nil];
// 修改实体对象的值
// 务必通过上下文同步到数据存储
[context save:&err];
查: // 先初始化抓取数据的请求,指定其抓取何种类型的实体对象
[[NSFetchRequest alloc] initWithEntityName:@"Favorite"];
// 指定其筛选数据的条件
request.predicate = [NSPredicate predicateWithFormat:@"newsId = %@",@(objId)];
// 执行抓取请求
[context executeFetchRequest:request error:nil];
CoreData的更多相关文章
- iOS基本数据库存储方式 - CoreData
CoreData 创建模型文件的过程 1.选择模板 2.添加实体 3.添加实体的属性[注意]属性的首字母必须小写 一.CoreData管理类(必备以下三个类对象) 1.CoreData数据操作的上下文 ...
- iOS CoreData 中 objectID 的不变性
关于 CoreData的 objectID 官方文档有这样的表述:新建的Object还没保存到持久化存储上,那么它的objectID是临时id,而保存之后,就是持久化的id,不会再变化了. 那么,我想 ...
- CoreData __ 基本原理
操作过程 Context想要获取值,先要告诉连接器,我要什么东西 链接器再告诉store, 你给我什么东西, store去找 找到之后返回给链接器,链接器再返回给Context Co ...
- iOS CoreData primitive accessor
Given an entity with an attribute firstName, Core Data automatically generates firstName, setFirstNa ...
- 初识CoreData与详解
Core Data数据持久化是对SQLite的一个升级,它是iOS集成的,在说Core Data之前,我们先说说在CoreData中使用的几个类. (1)NSManagedObjectModel(被管 ...
- CoreData教程
网上关于CoreData的教程能搜到不少,但很多都是点到即止,真正实用的部分都没有讲到,而基本不需要的地方又讲了太多,所以我打算根据我的使用情况写这么一篇实用教程.内容将包括:创建entity.创建r ...
- CoreData和SQLite多线程访问时的线程安全
关于CoreData和SQLite多线程访问时的线程安全问题 数据库读取操作一般都是多线程访问的.在对数据进行读取时,我们要保证其当前状态不能被修改,即读取时加锁,否则就会出现数据错误混乱.IOS中常 ...
- IOS数据存储之CoreData使用优缺点
前言: 学习了Sqlite数据之后认真思考了一下,对于已经习惯使用orm数据库的开发者或者对sql语句小白的开发者来说该如何做好数据库开发呢?这个上网搜了一下?看来总李多虑了!apple 提供了一种数 ...
- iOS开发之表视图爱上CoreData
在接触到CoreData时,感觉就是苹果封装的一个ORM.CoreData负责在Model的实体和sqllite建立关联,数据模型的实体类就相当于Java中的JavaBean, 而CoreData的功 ...
随机推荐
- ASP.NET Core中的依赖注入(5): ServiceProvider实现揭秘 【总体设计 】
本系列前面的文章我们主要以编程的角度对ASP.NET Core的依赖注入系统进行了详细的介绍,如果读者朋友们对这些内容具有深刻的理解,我相信你们已经可以正确是使用这些与依赖注入相关的API了.如果你还 ...
- 初学ReactJS,写了一个RadioButtonList组件
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title>React Demo</title> ...
- 本地maven仓库使用及配置
本地仓库的创建 下载 nexus-2.11.4-01-bundle.zip 解压并运行C:\nexus-2.11.4-01-bundle\nexus-2.11.4-01\bin\jsw\windows ...
- vmware安装win7提示No CD-ROM drive to use:GCDROM not loaded
今天安装win7 64位的操作系统到vmware虚拟机,以为一切事如此的简单,因为自己以前经常拿vmware来装系统,结果确出现下面莫名其妙的错误: 提示说没有CD-ROM,可是我明明在vmware的 ...
- ASP.NET 5 单元测试中使用依赖注入
相关博文:<ASP.NET 5 使用 TestServer 进行单元测试> 在上一篇博文中,主要说的是,使用 TestServer 对 ASP.NET 5 WebApi 进行单元测试,依赖 ...
- EntityFramework 如何进行异步化(关键词:async·await·SaveChangesAsync·ToListAsync)
应用程序为什么要异步化?关于这个原因就不多说了,至于现有项目中代码异步化改进,可以参考:实际案例:在现有代码中通过async/await实现并行 这篇博文内容针对的是,EntityFramework ...
- 小菜学习Winform(一)贪吃蛇
前言 说到贪吃蛇,大家可能小时候都玩过,小菜最近在整理Winfrom的学习系列,那我觉得有兴趣才会有学习,就从这个小游戏讲起吧. 实现 其实我刚开始学习编程的时候,感觉写个贪吃蛇的程序会很难,因为涉及 ...
- SQL Server基础之《视图的概述和基本操作》
数据库中的视图是一个虚拟表.同真实的表一样,视图包含一系列带有名称的列和行数据,行和列数据用来自由定义视图和查询所引用的表,并且在引用视图时动态产生.本篇将通过一些实例来介绍视图的概念,视图的作用, ...
- rsa互通密钥对生成及互通加解密(c#,java,php)
摘要 在数据安全上rsa起着非常大的作用,特别是数据网络通讯的安全上.当异构系统在数据网络通讯上对安全性有所要求时,rsa将作为其中的一种选择,此时rsa的互通性就显得尤为重要了. 本文参考网络资料, ...
- jquery鼠标移动div内容上下左右滚动
jquery鼠标移动div内容上下左右滚动 点击这里查看效果:http://keleyi.com/keleyi/phtml/jqtexiao/9.htm <!DOCTYPE html PUBLI ...