Coredata

一. CoreData 是什么?

  • Core Data 是 iOS SDK 里的一个很强大的框架,允许程序员以面向对象的方式储存和管理数据。使用 Core Data 框架,程序员可以很轻松有效地通过面向对象的接口管理数据
  • Core Data 是一个模型层的技术。帮助建立代表程序状态的模型层,Core Data 也是一种 持久化技术,能将模型对象的状态持久化到磁盘,但它最重要的特点是: ** Core Data 不仅是一个加载、保存数据的框架,它还能和内存中的数据很好的共事**
  • 在数据操作过程中, 无需编写任何SQL语句
  • Core Data 使用包括实体实体间关系,以及查找符合某些条件实体的请求等内容
  • 开发者可以在纯对象层上查找与管理这些数据,而不必担心存储和查找的实现细节
  • Core Data 框架最早出现在 Mac OS X 10.4 Tiger 与 iOS 3.0 系统,经过成千上万的应用程序以及数以百万用户的反复的验证,Core Data 确实已经是一套非常成熟的框架
  • CoreData利用了Objective-C语言和运行时,巧妙地集成了CoreFoundation框架。是 一个易于使用的框架,不仅可以优雅地管理对象图,而且在内存管理方面表现异常优异

二. 怎么学习CoreData

  • 第一眼看到 Core Data 令人生畏的复杂架构关系,很多人都会有无从下手的感觉.
  • 可是, 一旦理解了架构图中各个部件的组成相互之间的关系,就能体会到 Core Data API 的简洁和直观了
  • Core Data stack(堆栈):如果能够理解 Core Data stack 中的各个成员所扮演的角色,那么再使用Core Data 就不会感觉到困难了
  • 误区:Core Data 不是一个数据库,不要用数据库的眼光去看待 Core Data
  • Core Data 不是应用程序的数据库,也不是将数据持久化保存到数据库的 API。Core Data 是一个用于管理对象图的框架。Core Data 可以把对象图写入磁盘从而持久化保存,但是这不是框架的主要目标.

三. Core Data stack

Core Data stack 是 Core Data 的核心,由一组 Core Data 核心对象组成

  • NSManagedObjectContext 对象管理上下文: 负责管理模型的对象的集合
  • NSManagedObjectModel 被管理的对象模型: 负责管理对象模型
  • NSPersistentStoreCoordinator 存储调度器: 负责将数据保存到磁盘的

三者之间关系示意图:

关系图

分为两部分:

  • 对象图管理
  • 数据持久化
    在这两部分的中间,即堆栈中间,是持久化存储协调器(Persistent Store Coordinator, PSC)。通过它将对象图管理部分和持久化部分绑在一起。当这两部分中的一部分需要和另一部分交互,将通过 PSC 来调节
对象图

常见的使用解决方案:

解决方案

四. 创建CoreDataStack

根据 CoreDataStack 示意图,将关系以代码的形式组织起来 !

// 实例化数据模型 
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:modelNamewithExtension:@"momd"];
NSManagedObjectModel *model = [[NSManagedObjectModel alloc]initWithContentsOfURL:modelURL];

// 实例化持久化储存
 NSPersistentStoreCoordinator *psc = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];

NSURL *dbURL = [[[NSFileManager defaultManager]URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask]lastObject];

dbURL = [dbURL URLByAppendingPathComponent:dbName];[psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil
URL:dbURL options:nil error:NULL];

//  实例化上下文
_managedObjectContext = [[NSManagedObjectContext alloc]initWithConcurrencyType:NSMainQueueConcurrencyType];

[_managedObjectContext setPersistentStoreCoordinator:psc];


[ 一些提示 ]

use scalar properties for primitive data type

在 iOS5 和 OS X10.7 之前,scalar 不能自动生成,程序员必须自己添加 setter 和 getter 的实现

@dynamic

在 Objective-C 中,如果将某个属性实现为@dynamic,意味着告诉编译器不会在编译时确定这个属性的行为实现,因此不需要在编译期间对这个属性的 getter、setter 做检查.


五. CoreData 常见操作

5.1 新增记录:

使用 NSEntityDescription 来创建对象,赋值后使用相应的 context 保存即可

新增

5.2 删除记录:

使用 context 的 deleteObject:删除被管理的模型对象后保存即可

删除记录

5.3 修改记录:

直接修改模型对象保存即可

修改记录

5.4 查询记录

对使用 CoreData 进行存储的数据进行一定条件的查询后取出来使用

5.4.1 谓词(is)---NSPredicate

作用:判断条件表达式的求值返回真或假的过程

使用步骤:

  • 定义 NSPredicate 对象并指定条件
  • 调用谓词的 evaluateWithObject 方法判断指定条件是否满足示例:
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"self CONTAINS '1'"];
NSString *text = @"1234";
NSLog(@"%d", [predicate evaluateWithObject:text]);

案例:

  1. 创建 Person 的对象数组
  2. 查询判断姓名和年龄的过滤方法
  • 传统方法
NSMutableArray *result = [NSMutableArray arrayWithCapacity:personList.count];

for (NSInteger i = 0; i < personList.count; i++)
 {
    Person *person = personList[i];
//  用户年龄小于5同时用户姓名中包含"1"字符串
    if (person.age < 5 && NSNotFound != [person.name rangeOfString:@"1"].location)
       {
           [result addObject:person];
       }
  }
return result;
  • 谓词方法
NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name CONTAINS '1' && %K BETWEEN {%d, %d}",@"age", 5, 15];

NSArray *result = [personList filteredArrayUsingPredicate:predicate];

谓词的条件指令

  1. > < == >= <= !=
    例如:
    @"number >= 99"

  2. 范围运算符IN BETWEEN
    例如:
    @"number BETWEEN {1,5}"
    @"address IN {'shanghai','nanjing'}"

  3. 字符串本身:SELF
    例如:
    @"SELF == 'APPLE'"

  4. 字符串相关: BEGINSWITH ENDSWITH CONTAINS

例如:

@"name CONTAIN[cd] 'ang'" //包含某个字符串
@"name BEGINSWITH[c] 'sh'" //以某个字符串开头
@"name ENDSWITH[d] 'ang'" //以某个字符串结尾
  1. 通配符:LIKE
    例如:
@"name LIKE[cd] '*er*'" //* 代表通配符,Like 代表接受 [cd].
@"name LIKE[cd] '???er*'"

 注:  星号"*" : 代表0或多个字符
        问号"?" : 代表一个字符
  1. 正则表达式:MATCHES
    例如:
NSString *regex = @"^A.+e$"; //以A开头, e结尾
@"name MATCHES %@",regex
注:[c]不区分大小写,[d]不区分发音符号即没有重音符号,[cd]既不区分大小写,也不区分发音符号.
  1. 合计操作
    ANY SOME: 指定下列表达式中的任意元素
    例如 ANY children.age < 18
    ALL: 指定下列表达式中的所有元素
    例如 ALL children.age < 18
    NONE: 指定下列表达式中没有的元素
    例如 NONE children.age < 18
    在逻辑上等于NOT(ANY ...)
    IN:等于 SQL的IN操作,左边的表达必须出现在与右边指定的集合中
    例如:name IN { 'Ben','Melissa', 'Nick' }

提示 :

  1. 谓词中的匹配指令关键字通常使用大写字母
  2. 谓词中可以使用格式字符串
  3. 如果通过对象的key path 指定匹配条件,需要使用 %K
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容