CoreData

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];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容