1.NSManagedObjectModel:被管理的对象模型,对应定义的模型文件,应用程序的数据模型,数据库中所有表和他们之间的联系,相当于数据表的描述文档(类似Hibernate模型XLM文件)
managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:(.xcdatamodeld文件的URL)];
2.NSPersistentStoreCoorinator:添加持久化数据库(SQLite数据库),是物理数据存储的物理文件和程序之间的桥梁,负责管理不同对象上下文,协调器通过NSManagedObjectModel创建数据库
persistentStoreCoordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:[self managedObjectModel]];
创建好协调器之后还要指定其数据库存储的地址。
NSError *error = nil;
NSString *failureReason = @"There was an error creating or loading the application's saved data.";
if (![_persistentStoreCoordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
// Report any error we got.
NSMutableDictionary *dict = [NSMutableDictionary dictionary];
dict[NSLocalizedDescriptionKey] = @"Failed to initialize the application's saved data";
dict[NSLocalizedFailureReasonErrorKey] = failureReason;
dict[NSUnderlyingErrorKey] = error;
error = [NSError errorWithDomain:@"YOUR_ERROR_DOMAIN" code:9999 userInfo:dict];
// Replace this with code to handle the error appropriately.
// abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
3.NSManagedObjectConText:负责应用和数据库之间的交互
managedObjectContext = [[NSManagedObjectContext alloc] initWithConcurrencyType:NSMainQueueConcurrencyType];
创建好上下文之后还要指定其协调器才能正常使用。上下文通过协调器拿到数据库中的所有表。
[managedObjectContext setPersistentStoreCoordinator:coordinator];
可以通过TA去访问底层的框架对象集合,这些对象集合统称为持久化堆栈(persistence stack)——它在应用程序和外部数据存储的对象之间提供访问通道
上下文的作用相当重要,对数据对象进行的操作都与它有关。当创建一个数据对象并插入 上下文 中,上下文就开始跟踪这个数据对象的一切变动,并在合适的时候提供对 undo/redo 的支持,或调用 Persistent Store Coordinato 将变化保存到数据文件中去
//redo: 恢复已经提交的事务 undo: 回滚操作,支持读一致性,恢复失败的事务
数据更新
NSError *error = nil;
if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {
NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
abort();
}
4.NSEntityDerscriotion:实体描述,(NSManagedObjectModel是所有表的集合, 而NSEntityDescription 相当于数据库中的一个表)
通过上下文,工厂方法,根据给定的 Entity 描述,生成相应的 NSManagedObject 对象,并插入到 ManagedObjectContext 中
Book *book1 = [NSEntityDescription insertNewObjectForEntityForName:@"表名" inManagedObjectContext:appDelegate.managedObjectContext];
通过上面的代码可以得到这个表的实例,然后可以使用这个实例直接去为表中的属性赋值
book.name=@"ios";
也可以通过上下文创建实体描述(表)
[NSEntityDescription entityForName:@"ZLAuthor" inManagedObjectContext:[self managedObjectContext]];
5.NSFetchRequest相当于一个查询语句,你必须指定要查询的 Entity。我们通过 Fetch Requests 向 Managed Object Context 查询符合条件的数据对象,以 NSArray 形式返回查询结果,如果我们没有设置任何查询条件,则返回该 Entity 的所有数据对象。我们可以使用谓词来设置查询条件,通常会将常用的 Fetch Requests 保存到 dictionary 以重复利用
(1)创建查询
NSFetchRequest * request = [[NSFetchRequest alloc] init]
(2)设置你要查询的数据对象的类型(Entity表)就是NSEntityDescription对象
[request setEntity:[NSEntityDescription entityForName:@"ZLAuthor" inManagedObjectContext:context]];
(3) 设置查询条件(谓词)
1.创建谓词
NSPredicate * predicate = [NSPredicate predicateWithFormat:@"xx > %@", xx];
2.设置谓词
[request setPredicate:predicate];
(4)设置最大查询对象数目
[request setFetchLimit:100];
(5)设置查询结果的排序方法NSArray< NSSortDescriptor>sortArry
NSSortDescriptor * sort = [[NSSortDescriptor alloc]initWithKey:@"Name" ascending:YES];
[request setSortDescriptors:@[sort]];
(6)执行 Fetch Request 并返回所有匹配的数据对象
NSArray * results = [context executeFetchRequest:fetch error:nil];