iOS记录篇程序员手机移动程序开发

Coredata

2016-01-11  本文已影响995人  Jimmy_P

一. CoreData 是什么?


二. 怎么学习CoreData


三. Core Data stack

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

三者之间关系示意图:

关系图

分为两部分:

对象图

常见的使用解决方案:

解决方案

四. 创建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 *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
上一篇下一篇

猜你喜欢

热点阅读