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的功 ...
随机推荐
- EntityFramework之孩子删除(四)(你以为你真的懂了?)
前言 从表面去看待事物视线总有点被层层薄雾笼罩的感觉,当你静下心来思考并让指尖飞梭于键盘之上,终将会拨开浓雾见青天.这是我切身体验. 在EF关系配置中,我暂且将主体对象称作为父亲,而依赖对象称作为孩子 ...
- 近期博客内容的规划(关于Swift语言)
因为最近事情比较多,有一段时间没有发表博客了.前一段时间,利用空余时间翻译了一本关于Swif的书籍,过一段时间就会出版吧.通过翻译此书,英语水平没提高多少,不过Swift算是系统的学习了一下. 在翻译 ...
- 相克军_Oracle体系_随堂笔记009-检查点队列
1.检查点队列 checkpoint queue RBA 日志块地址 redo block address LRBA 第一次被脏的地址 HRBA 最近一次被脏的地址 on disk rba 重做日志( ...
- MySQL入门01-MySQL源码安装
操作系统:CentOS 6.7 MySQL版本:5.6.30 1.前期准备 2.系统配置 3.CMake编译配置 4.make && make install 5.后期配置和测试 Re ...
- Hive启动报错: Found class jline.Terminal, but interface was expected
报错: [ERROR] Terminal initialization failed; falling back to unsupported java.lang.IncompatibleClassC ...
- SQL之收集SQL Server线程等待信息
要知道线程等待时间是制约SQL Server效率的重要原因,这一个随笔中将学习怎样收集SQL Server中的线程等待时间,类型等信息,这些信息是进行数据库优化的依据. sys.dm_os_wait_ ...
- 一言不合就动手系列篇一-仿电商平台前端搜索插件(filterMore)
话说某年某月某日,后台系统需要重构,当时公司还没有专业前端,由我负责前台页面框架搭建,做过后台系统的都知道,传统的管理系统大部分都是列表界面和编辑界面.列表界面又由表格和搜索框组成, 对于全部都是输入 ...
- Java进击C#——语法之面向对象
本章简言 上一章笔者讲到关于ADO.NET相关的知识,知道了如何去访问数据库.本章将来讲关于面向对象的思想.不管在JAVA还是在C#面向对象思想的重要性都是占了一个很大的成份.往往他就像呼吸一样子,更 ...
- WCF学习系列三--【WCF Interview Questions – Part 3 翻译系列】
http://www.topwcftutorials.net/2012/10/wcf-faqs-part3.html WCF Interview Questions – Part 3 This WCF ...
- 3.Code-First 约定(EF Code-First系列)
前面,我们已经了解了Code-First利用领域类,怎么为我们创建数据库的简单示例.现在我们来学习一下Code-First约定吧. 什么是约定 约定说白了,就是基于一套规矩办事,这里就是基于你定义好的 ...