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的功 ...
随机推荐
- Web APi之消息处理管道(五)
前言 MVC有一套请求处理的机制,当然Web API也有自己的一套消息处理管道,该消息处理管道贯穿始终都是通过HttpMessageHandler来完成.我们知道请求信息存在 RequestMessa ...
- html5 meta(移动端)介绍及使用
随着高端手机(Andriod,Iphone,Ipod,WinPhone等)的盛行,移动互联应用开发也越来越受到人们的重视,用html5开发移动应用是最好的选择.然而,每一款手机有不同的分辨率,不同屏幕 ...
- 相克军_Oracle体系_随堂笔记005-Database buffer cache
本章主要阐述SGA中的Database buffer cache. Buffer cache { 1.pin (读写瞬间的状态) 2.clean 3.dirty 4.unused } --Databa ...
- Cesium原理篇:3最长的一帧之地形(4:重采样)
地形部分的原理介绍的差不多了,但之前还有一个刻意忽略的地方,就是地形的重采样.通俗的讲,如果当前Tile没有地形数据的话,则会从他父类的地形数据中取它所对应的四分之一的地形数据.打个比方 ...
- 百度eCharts体验
前言 从昨天开始给项目里添加一些图表对比功能,上一个项目里使用的是Highcharts,本打算继续用Highcharts做的,昨天试了下做出来的效果不太好,主要也是因为看的多了没什么新鲜感了,于是便尝 ...
- 关于jqGrig如何写自定义格式化函数将JSON数据的字符串转换为表格各个列的值
首先介绍一下jqGrid是一个jQuery的一个表格框架,现在有一个需求就是将数据库表的数据拿出来显示出来,分别有id,name,details三个字段,其中难点就是details字段,它的数据是这样 ...
- Struts2 源码分析——调结者(Dispatcher)之执行action
章节简言 上一章笔者写关于Dispatcher类如何处理接受来的request请求.当然读者们也知道他并非正真的执行action操作.他只是在执行action操作之前的准备工作.那么谁才是正真的执行a ...
- 细说ASP.NET Core静态文件的缓存方式
一.前言 我们在优化Web服务的时候,对于静态的资源文件,通常都是通过客户端缓存.服务器缓存.CDN缓存,这三种方式来缓解客户端对于Web服务器的连接请求压力的. 本文指在这三个方面,在ASP.NET ...
- null和undefined的一些区别
读了阮一峰的博客,自己总结一下,便记录一篇博客 在javacript的基本类型中,有2种基本类型,只有1个值,便是null和undefined,都表示的是"无".在一定程度上是相等 ...
- 转: GUI应用程序架构的十年变迁:MVC,MVP,MVVM,Unidirectional,Clean
十年前,Martin Fowler撰写了 GUI Architectures 一文,至今被奉为经典.本文所谈的所谓架构二字,核心即是对于对于富客户端的 代码组织/职责划分 .纵览这十年内的架构模式变迁 ...