标签: IOS-OC
[toc]
功能介绍
CoreData核心数据库,是cocoa框架中得一个用于管理数据库和对象之间映射关系的一套支持库,它主要提供ORM(对象关系映射)功能,可以将OC对象转化为数据,保存在本地数据库也可以将数据库中的数据还原成OC对象,极大的简化了操作.CoreData不仅支持SQLite数据库还支持XML,内存和二进制文件的储存
库文件
CoreData.framework
涉及类
类名 | 所属库 | 功能 |
---|---|---|
NSManaged Object Model | CoreData | 描述应用程序的数据模型,这个模型包含实体(Entity),特性(Property),读取请求 |
NSManaged Object Context | CoreData | 参与对数据对象进行操作的全过程,并检测数据对象的变化,以提供对undo/redo的支持及更新绑 定到数据的UI. |
NSManaged Object | CoreData | 数据对象,用于储存从数据库获得的数据,与ManagedObjectContext关联. |
NSPersisterStore Coordinator | CoreDara | 数据文件管理器,用于处理对数据库的增删改查操作.一般不需要对这个类进行操作. |
NSEntityDescription | CoreData | 表实体结构,管理表的结构,从表结构中创建实体类 |
NSSortDescriptor | Foundation | 负责管理查询数据时,数据的排列方式 |
NSFetchRequest | CoreData | 查询结果集,主要用于查询数据,并返回结果,可以设置查询条件和查询顺序 |
NSPredicate | Foundation | 谓词条件,使用谓词来为FetchRuquest设置查询条件 |
创建数据库模型文件
1.选择模板
Command + N打开新建文件窗口,选择Core Data目录中的Data Model然后Next
2.创建模型实体
这里创建了一个名叫People的实例数据库,里面有两个字段age和name分别是整型和字符串类型的
使用代码对数据库进行操作
1.编写代码创建上下文
: 新建一个继承与NSObjcet的类,创建一个NSManagedObjectContext属性,命名为ManagedObjectContext
- (instancetype)init{
self = [super init];
if (self) {
//获取数据库模型的本地url Model.xcdatamodeld编译后的后缀为momd;
NSURL * modelUrl = [[NSBundle mainBundle] URLForResource:@"Model" withExtension:@"momd"];
//创建模型对象,从数据库模型中创建对象
NSManagedObjectModel * model = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelUrl];
//创建文件管理器管理模型对象.
NSPersistentStoreCoordinator * store = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];
//设置数据库文件保存的路径,后缀为sqlite
NSURL * dataURL = [[[[NSFileManager defaultManager]URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask] lastObject]URLByAppendingPathComponent:@"mySQL.sqlite"];
NSError * error = nil;
//生成本地数据库文件,并设置生成文件的类型为SQLite
[store addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:dataURL options:nil error:&error];
if (error) {
NSLog(@"创建数据库失败!");
abort();
}else{
//生成文件成功,创建用于操作数据库的上下文
_managerObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
//设置上下文操作的数据库管理器,不需要直接操作PersistentStoreCoordinator,我们只要操作上下文就可以对数据库进行增删改查.
[_managerObjectContext setPersistentStoreCoordinator:store];
}
}
return self;
}
2.为数据库添加一条数据
:
//增
- (void)addPeopleObjectWithPeopleName:(NSString *)name peopleAge:(NSNumber *)age{
//根据People实体模型创建一个新的People对象,并加入上下文管理
NSManagedObject * people = [NSEntityDescription insertNewObjectForEntityForName:@"People" inManagedObjectContext:_managerObjectContext];
//设置people的属性
[people setValue:name forKey:@"name"];
[people setValue:age forKey:@"age"];
//同步数据到本地数据库.这里要注意下,即使没有保存到本地,依然能查找到这个条目,只不过APP下次运行就没有了.
if([_managerObjectContext save:nil]){
NSLog(@"保存数据成功!");
}
}
3.查询数据,数据排序
:
//按照年龄排序并查找年龄小于1的条目
- (NSArray *)sortPeopleWithAge{
//创建一个结果集
NSFetchRequest * request = [[NSFetchRequest alloc] init];
//设置结果集所对应的实体和上下文,这里表示查询People实体内的数据, 这里的People要和模型文件中得实体名称相同
request.entity = [NSEntityDescription entityForName:@"People" inManagedObjectContext:_managerObjectContext];
//创建一个排序规则,按照age进行升序排列
NSSortDescriptor * sort = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:YES];
//可以添加多个排序规则
request.sortDescriptors = @[sort];
//添加谓词,为查找指定条件为 age属性大于1的条目
NSPredicate * predicate = [NSPredicate predicateWithFormat:@"age > 1"];
request.predicate = predicate;
//获取查找结果
NSArray * array = [_managerObjectContext executeFetchRequest:request error:nil];
return array;
}
4.修改数据
:
//改
- (NSManagedObject *)updatePeopleName:(NSString *)name toNewName:(NSString *)newName{
//查找要修改的数据条目
NSManagedObject * people = [self peopleObjectWithName:name];
//修改属性
[people setValue:newName forKey:@"name"];
//同步保存到本地数据库
[_managerObjectContext save:nil];
return people;
}
5.删除一条数据
:
//删
- (void)deletePeopleObjectWithName:(NSString *)name{
//查找要删除的数据条目
NSManagedObject * people = [self peopleObjectWithName:name];
//删除条目
[_managerObjectContext deleteObject:people];
//同步保存到本地数据库
if([_managerObjectContext save:nil]){
NSLog(@"删除成功!");
}
}
注:在使用context保存之前所做的更改如:创建新的对象,删除对象,修改对象属性,一样会影响FetchRequest查找到的数据,但是不会影响本地储存的数据,[context save]方法的作用是将程序内存中所有的数据库数据同步储存到本地.可以使用[context hasChange]方法来判断本地数据和内存中的数据是否一致.