CoreData的使用

CoreData介绍

CoreData是一个模型层的技术,也是一种持久化技术(数据库),它能将模型对象的状态持久化到磁盘里,我们不需要使用SQL语句就能对它进行操作。

创建DataModel

New File -> iOS -> Core Data ->Data Model

3221470-e8e06be7534637fd.png

名字虽然可以任意取,但最好还是取和自己存储数据库名字一样的名字。这样可读性更高些。这个文件就相当于数据库文件一样,数据库文件中可以有多个表,表中可以有各个字段值,这里也可以有多个实体,每个实体有各个键值。

创建Entity
3221470-38a8b250426cdc09.png
  • 点击.xcdatamodeld文件,在最下面找到Add Entity按钮,进行实体添加。
  • 修改Entity名字,双击一下即可修改名字,或者在xcode右边的信息栏中也可以修改
  • 往实体中添加我们需要的键值(相当于数据库表中的字段)。
创建关联类

选中.xcdatamodeld文件->xcode菜单栏->Edit->Create NSManagedObject Subclass

3221470-431fad40171793ed.png

选中自己需要关联的.xcdatamodeld文件名称,点击下一步即可。

3221470-0482891f3f696849.png

选中.xcdatamodeld文件中需要关联的实体对象,点击下一步然后在选择存储目录即可。

3221470-897111a2d8f13610.png

完成后会发现自动生成了实体名称对应的类和扩展类(Entity.h/.m和Entity+CoreDataProperties.h/.m)

注意:在Code Generation修改你使用语言是Swift还是Objective-C

CoreData API

  • NSManagedObjectContext
  • NSManagedObjectModel
  • NSPersistentStoreCoordinator
  • NSEntityDescription
#import <CoreData/CoreData.h>
NSManagedObjectContext

用来管理.xcdatamodeld中的数据,负责数据和应用库之间的交互(CRUD,即增删改查、保存等接口都是用这个对象调用)。

// 不能为 NSManagedObjectContext 实例提供一个线程, iOS9.0 弃用
self.context = [[NSManagedObjectContext alloc] init];

// NSMainQueueConcurrencyType 主线程
// NSPrivateQueueConcurrencyType 另外创建一个后台线程
self.context = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
NSManagedObjectModel

CoreData的模型文件(个人理解:表示一个.xcdatamodeld文件)。

// 1.主动加载指定名称的.xcdatamodeld资源
//获取模型路径
NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"CoreDataDemo" withExtension:@"momd"];
//根据模型文件创建模型对象
NSManagedObjectModel *model = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
// 2.从应用程序包中加载.xcdatamodeld模型文件                              
NSManagedObjectModel *model = [NSManagedObjectModel mergedModelFromBundles:nil];
NSPersistentStoreCoordinator

持久化存储库,CoreData的存储类型。

  • 用来将对象管理部分和持久化部分捆绑在一起,负责相互之间的交流(中介一样)。
  • 用来设置CoreData存储类型和存储路径。
NSPersistentStoreCoordinator *persistent = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];
/*
   持久化存储库的类型:
   NSSQLiteStoreType  SQLite数据库
   NSBinaryStoreType  二进制平面文件
   NSInMemoryStoreType 内存库,无法永久保存数据
 */
NSString *sqlPath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"CoreDataDemo.sqlite"];

NSError *error = nil;

[coordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:[NSURL fileURLWithPath:sqlPath] options:nil error:&error];
NSEntityDescription

用来描述实体(Entity),通过CoreData从数据库中取出的对象,默认情况下都是NSManagedObject对象。

// 注意:不能用 alloc init方式创建
// 创建方式(用于插入数据使用:获得实体,改变实体各个属性值,保存后就代表插入)
Student *stutent = [NSEntityDescription insertNewObjectForEntityForName:@"Student" inManagedObjectContext:self.context];

CoreData操作

需要通过NSManagedObjectContext对象操作CoreData的增删改查。

insert
// 1.根据Entity名称和NSManagedObjectContext获取一个新的NSManagedObject
Student *stutent = [NSEntityDescription insertNewObjectForEntityForName:@"Student" inManagedObjectContext:self.context];
    
// 2.根据Entity中的键值,一一对应通过setValue:forkey:给NSManagedObject对象赋值
stutent.stuID = @"0001";
stutent.name = @"张三";
stutent.age = 18;
    
// 3.保存修改
NSError *error = nil;
BOOL result = [self.context save:&error];
if (result) {
    NSLog(@"保存成功...");
} else {
    NSLog(@"保存失败:%@", error);
}
query
// NSFetchRequest: Core Data中,用于查询数据的类
// 1.根据Entity名称创建查询请求对象
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Student"];

// 2.设置查询过略
fetchRequest.predicate = [NSPredicate predicateWithFormat:@"age <= 60"];

// 3.设置排序器
NSSortDescriptor *ageDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"age" ascending:YES];
NSSortDescriptor *nameDescriptor = [NSSortDescriptor sortDescriptorWithKey:@"name" ascending:YES];
// 排序器,可以指定多个排序器,优先顺序以数组先后顺序
fetchRequest.sortDescriptors = @[nameDescriptor, ageDescriptor];

// 4.执行查询,结果是模型的集合
NSError *error = nil;
NSArray *objs = [self.context executeFetchRequest:fetchRequest error:&error];
if (!error) {
    for (Student *student in results) {
        NSLog(@"%@: %d", student.name, student.age);
    }
} else {
    NSLog(@"查询失败:%@", error);
}
delete
// 1.根据Entity名称和NSManagedObjectContext通过谓语取出符合的Entity集合
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Student"];
fetchRequest.predicate = [NSPredicate predicateWithFormat:@"age < 50"];    
NSArray *objs = [self.context executeFetchRequest:fetchRequest error:nil];

// 2.删除集合内的Entity
for (Student *student in objs) {
    [self.context deleteObject:student];
}

// 3.保存修改
NSError *error = nil;
BOOL result = [self.context save:&error];
if (result) {
    NSLog(@"保存成功...");
} else {
    NSLog(@"保存失败:%@", error);
}
update
// 1.根据Entity名称和NSManagedObjectContext通过谓语取出符合的Entity集合
NSFetchRequest *fetchRequest = [NSFetchRequest fetchRequestWithEntityName:@"Student"];
fetchRequest.predicate = [NSPredicate predicateWithFormat:@"age = 18"];    
NSArray *objs = [self.context executeFetchRequest:fetchRequest error:nil];

// 2.修改Entity
Student *student = [objs lastObject];
student.age = 25;

// 3.保存修改
NSError *error = nil;
BOOL result = [self.context save:&error];
if (result) {
    NSLog(@"保存成功...");
} else {
    NSLog(@"保存失败:%@", error);
}

猜你喜欢

转载自blog.csdn.net/weixin_34128237/article/details/87233698