CoreData中的核心对象
注:黑色表示类名,红色表示类里面的一个属性
开发步骤总结:
1.初始化NSManagedObjectModel对象,加载模型文件,读取app中的所有实体信息
2.初始化NSPersistentStoreCoordinator对象,添加持久化库(这里采取SQLite数据库)
3.初始化NSManagedObjectContext对象,拿到这个上下文对象操作实体,进行CRUD操作
1.初始化NSManagedObjectModel对象,加载模型文件,读取app中的所有实体信息
2.初始化NSPersistentStoreCoordinator对象,添加持久化库(这里采取SQLite数据库)
3.初始化NSManagedObjectContext对象,拿到这个上下文对象操作实体,进行CRUD操作
1.搭建上下文环境
注:Core Data不会根据实体中的关联关系立即获取相应的关联对象,比如通过Core Data取出Person实体时,并不会立即查询相关联的Card实体;当应用真的需要使用Card时,才会再次查询数据库,加载Card实体的信息。这个就是Core Data的延迟加载机制
4.删除数据库中的数据
2.点击Arguments,在ArgumentsPassed On Launch中添加2项
1> -com.apple.CoreData.SQLDebug
2> 1
Card.h
Card.m
那么往数据库中添加数据的时候就应该写了:
- // 从应用程序包中加载模型文件
- NSManagedObjectModel *model = [NSManagedObjectModel mergedModelFromBundles:nil];
- // 传入模型对象,初始化NSPersistentStoreCoordinator
- NSPersistentStoreCoordinator *psc = [[[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model] autorelease];
- // 构建SQLite数据库文件的路径
- NSString *docs = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
- NSURL *url = [NSURL fileURLWithPath:[docs stringByAppendingPathComponent:@"person.data"]];
- // 添加持久化存储库,这里使用SQLite作为存储库
- NSError *error = nil;
- NSPersistentStore *store = [psc addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:url options:nil error:&error];
- if (store == nil) { // 直接抛异常
- [NSException raise:@"添加数据库错误" format:@"%@", [error localizedDescription]];
- }
- // 初始化上下文,设置persistentStoreCoordinator属性
- NSManagedObjectContext *context = [[NSManagedObjectContext alloc] init];
- context.persistentStoreCoordinator = psc;
- // 用完之后,记得要[context release];
2.添加数据到数据库
- // 传入上下文,创建一个Person实体对象
- NSManagedObject *person = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:context];
- // 设置Person的简单属性
- [person setValue:@"MJ" forKey:@"name"];
- [person setValue:[NSNumber numberWithInt:27] forKey:@"age"];
- // 传入上下文,创建一个Card实体对象
- NSManagedObject *card = [NSEntityDescription insertNewObjectForEntityForName:@"Card" inManagedObjectContext:context];
- [card setValue:@"4414241933432" forKey:@"no"];
- // 设置Person和Card之间的关联关系
- [person setValue:card forKey:@"card"];
- // 利用上下文对象,将数据同步到持久化存储库
- NSError *error = nil;
- BOOL success = [context save:&error];
- if (!success) {
- [NSException raise:@"访问数据库错误" format:@"%@", [error localizedDescription]];
- }
- // 如果是想做更新操作:只要在更改了实体对象的属性后调用[context save:&error],就能将更改的数据同步到数据库
3.从数据库中查询数据
- // 初始化一个查询请求
- NSFetchRequest *request = [[[NSFetchRequest alloc] init] autorelease];
- // 设置要查询的实体
- request.entity = [NSEntityDescription entityForName:@"Person" inManagedObjectContext:context];
- // 设置排序(按照age降序)
- NSSortDescriptor *sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:NO];
- request.sortDescriptors = [NSArray arrayWithObject:sort];
- // 设置条件过滤(搜索name中包含字符串"Itcast-1"的记录,注意:设置条件过滤时,数据库SQL语句中的%要用*来代替,所以%Itcast-1%应该写成*Itcast-1*)
- NSPredicate *predicate = [NSPredicate predicateWithFormat:@"name like %@", @"*Itcast-1*"];
- request.predicate = predicate;
- // 执行请求
- NSError *error = nil;
- NSArray *objs = [context executeFetchRequest:request error:&error];
- if (error) {
- [NSException raise:@"查询错误" format:@"%@", [error localizedDescription]];
- }
- // 遍历数据
- for (NSManagedObject *obj in objs) {
- NSLog(@"name=%@", [obj valueForKey:@"name"]
- }
4.删除数据库中的数据
- // 传入需要删除的实体对象
- [context deleteObject:managedObject];
- // 将结果同步到数据库
- NSError *error = nil;
- [context save:&error];
- if (error) {
- [NSException raise:@"删除错误" format:@"%@", [error localizedDescription]];
- }
打开CoreData的SQL语句输出开关
1.打开Product,点击EditScheme...2.点击Arguments,在ArgumentsPassed On Launch中添加2项
1> -com.apple.CoreData.SQLDebug
2> 1
创建NSManagedObject的子类
默认情况下,利用Core Data取出的实体都是NSManagedObject类型的,能够利用键-值对来存取数据。但是一般情况下,实体在存取数据的基础上,有时还需要添加一些业务方法来完成一些其他任务,那么就必须创建NSManagedObject的子类选择模型文件
选择需要创建子类的实体
创建完毕后,多了2个子类
文件内容展示:
Person.h
- #import <Foundation/Foundation.h>
- #import <CoreData/CoreData.h>
- @class Card;
- @interface Person : NSManagedObject
- @property (nonatomic, retain) NSString * name;
- @property (nonatomic, retain) NSNumber * age;
- @property (nonatomic, retain) Card *card;
- @end
Person.m
- #import "Person.h"
- @implementation Person
- @dynamic name;
- @dynamic age;
- @dynamic card;
- @end
Card.h
- #import <Foundation/Foundation.h>
- #import <CoreData/CoreData.h>
- @class Person;
- @interface Card : NSManagedObject
- @property (nonatomic, retain) NSString * no;
- @property (nonatomic, retain) Person *person;
- @end
Card.m
- #import "Card.h"
- #import "Person.h"
- @implementation Card
- @dynamic no;
- @dynamic person;
- @end
那么往数据库中添加数据的时候就应该写了:
- Person *person = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:context];
- person.name = @"MJ";
- person.age = [NSNumber numberWithInt:27];
- Card *card = [NSEntityDescription insertNewObjectForEntityForName:@”Card" inManagedObjectContext:context];
- card.no = @”4414245465656";
- person.card = card;
- // 最后调用[context save&error];保存数据