Core Data

Core Data 是数据持久化存储的最佳方式sql

数据最终的存储类型能够是:SQLite数据库,XML,二进制,内存,或自定义数据类型数据库

好处:可以合理管理内存,避免使用sql的麻烦,高效数组

构成:xcode

(1)NSManagedObjectContext(被管理的数据上下文)数据结构

操做实际内容(操做持久层)app

做用:插入数据,查询数据,删除数据框架

(2)NSManagedObjectModel(被管理的数据模型)编辑器

数据库全部表格或数据结构,包含各实体的定义信息工具

做用:添加实体的属性,创建属性之间的关系fetch

操做方法:视图编辑器,或代码

(3)NSPersistentStoreCoordinator(持久化存储助理)

至关于数据库的链接器

做用:设置数据存储的名字,位置,存储方式,和存储时机

(4)NSManagedObject(被管理的数据记录)

至关于数据库中的表格记录

(5)NSFetchRequest(获取数据的请求)

至关于查询语句

(6)NSEntityDescription(实体结构)

至关于表格结构

(7)后缀为.xcdatamodeld的包

里面是.xcdatamodel文件,用数据模型编辑器编辑

编译后为.momd或.mom文件

构建流程

包括:建立数据上下文,建立数据模型,建立数据持久化存储助理

生成的工程文件AppDelegate中,会自动生成被管理的数据上下文等相关代码

方法saveContext表示:保存数据到持久层(数据库)

方法applicationDocumentsDirectory表示:应用程序沙箱下的Documents目录路径

- (void)saveData{

    

    Person * person = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:[CYYCoreDataManage shareCoreData].managedContext];

    person.name = @"lisi";

    person.age = @(29);

    person.sex = @(YES);

    

    

    [[CYYCoreDataManage shareCoreData].managedContext save:nil];


}

被管理的数据上下文

初始化的后,必须设置持久化存储助理

-(NSManagedObjectContext *)managedContext{

    if (_managedContext == nil) {

        _managedContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];

        

        

        

        NSManagedObjectModel * model = [[NSManagedObjectModel alloc]initWithContentsOfURL:[[NSBundle mainBundle] URLForResource:@"Person" withExtension:@"momd"]];

        //协调器

        NSPersistentStoreCoordinator * per = [[NSPersistentStoreCoordinator alloc]initWithManagedObjectModel:model];

        

        NSURL * url = [NSURL fileURLWithPath:@"/Users/cai/Desktop/Person/person.db"];

        [per addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:url options:nil error:nil];

        

        [_managedContext setPersistentStoreCoordinator:per];

        

    }

    return _managedContext;

}

若是不是新工程,也能够本身写入相关代码

(4)此外还生成了TestApp.xcdatamodeld文件

(5)还自动连接了CoreData.framework

(6)在预编译头.pch文件中,加入导入了CoreData.h头文件

#import <CoreData/CoreData.h>

2.建立数据模型(数据模型编辑器操做)

(1)建立实体

选中.xcodedatamodel对象,在右边的数据模型编辑器的底部工具栏点击Add Entity添加实体,在最右侧栏对实体命名

(2)建立实体属性

 3.插入数据

AppDelegate.m的application:didFinishLaunchingWithOptions:方法里,调用自定义方法,insertCoreData插入数据

建立数据上下文,调用insertNewObjectForName方法,建立两个数据记录NSManagedObject,而后就能够对以前数据模型编辑视图中定义的属性进行赋值。此时的数据只在内存中被修改,最后调用数据上下文的save方法,保存到持久层

4.查询数据

调用了insertCoreData以后,能够调用自定的查询方法dataFetchRequest来查询插入的数据

- (void)fecthData{

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];

    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Person" inManagedObjectContext:[CYYCoreDataManage shareCoreData].managedContext];

    [fetchRequest setEntity:entity];

    // Specify criteria for filtering which objects to fetch

    NSPredicate *predicate = [NSPredicate predicateWithFormat:@"sex = %@",@"1" ];

    [fetchRequest setPredicate:predicate];

    // Specify how the fetched objects should be sorted

    NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"age" ascending:YES];

    [fetchRequest setSortDescriptors:[NSArray arrayWithObjects:sortDescriptor, nil]];

 

    NSArray *fetchedObjects = [[CYYCoreDataManage shareCoreData].managedContext executeFetchRequest:fetchRequest error:nil];

    for (Person * person in fetchedObjects) {

        NSLog(@"name = %@",person.name);

    }


fetchRequest至关于sql查询语句的包装类,须要用setEntity方法,来指定具体查询的实体结构(表结构)

经过NSEntityDescription的entityForName方法来,返回指向该具体实体结构的指针

而后调用executeFetchRequest:error:方法,来执行查询操做,若是操做成功,则返回对应的数据记录数组

其中,能够经过NSManagedObject数据记录对象里关联的属性,查询另外一个数据记录对象里的属性

5.数据模版

为每一个实体生成一个NSManagedObject子类

上面设置数据和获取数据时,使用的是Key-Value方式,更好的方法是经过生成强类型的NSManagedObject的子类,经过类的成员属性来访问和获取数据

(1)在数据编辑器视图中选中实体对象,

选则file菜单,点击new,点击file...,选择Core Data项,选择NSManagedObject subclass,生成该实体同名的类,

继承于NSManagedObject,生成对应的ContactInfo.h文件和ContactInfo.m文件

@dynamic告诉编译器不作处理,使编译经过,其getter和setter方法会在运行时动态建立,由Core Data框架为此类属性生成存取方法

相关文章
相关标签/搜索