您的位置:首页 > 数据库

IOS-Coredata 核心数据库的基础使用

2016-04-21 10:44 399 查看
demo资源链接

功能介绍

CoreData核心数据库,是cocoa框架中得一个用于管理数据库和对象之间映射关系的一套支持库,它主要提供ORM(对象关系映射)功能,可以将OC对象转化为数据,保存在本地数据库也可以将数据库中的数据还原成OC对象,极大的简化了操作.CoreData不仅支持SQLite数据库还支持XML,内存和二进制文件的储存

库文件

CoreData.framework

涉及类

类名所属库功能
NSManaged Object ModelCoreData描述应用程序的数据模型,这个模型包含实体(Entity),特性(Property),读取请求
NSManaged Object ContextCoreData参与对数据对象进行操作的全过程,并检测数据对象的变化,以提供对undo/redo的支持及更新绑 定到数据的UI.
NSManaged ObjectCoreData数据对象,用于储存从数据库获得的数据,与ManagedObjectContext关联.
NSPersisterStore CoordinatorCoreDara数据文件管理器,用于处理对数据库的增删改查操作.一般不需要对这个类进行操作.
NSEntityDescriptionCoreData表实体结构,管理表的结构,从表结构中创建实体类
NSSortDescriptorFoundation负责管理查询数据时,数据的排列方式
NSFetchRequestCoreData查询结果集,主要用于查询数据,并返回结果,可以设置查询条件和查询顺序
NSPredicateFoundation谓词条件,使用谓词来为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]方法来判断本地数据和内存中的数据是否一致.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: