表格结构:NSEntityDescription 相当于数据库中的一个表,TA描述一种抽象数据类型
eg:
//+insertNewObjectForEntityForName:inManagedObjectContext: 工厂方法,根据给定的 Entity 描述,生成相应的 NSManagedObject 对象,并插入到 ManagedObjectContext 中
Student *student = [NSEntityDescription insertNewObjectForEntityForName:@"Student" inManagedObjectContext:managedObjectContext];
//通过上面的代码可以得到student这个表的实例,然后可以使用这个实例去为表中的属性赋值
student.name = @"like"; student.age = 12;
应用程序的数据模型,数据库中所有表格和他们之间的联系:NSManagedObjectModel
//系统会读取model文件来声称NSManagedObjectModel对象,
model :对于class,model称之为 entity; 对于instant variable, model 称之为property
model包含两种property: attributes 和 relationships. attribute为简单数据类型,如一个字符串,日期,数字
NSManagedObjectModel * model = [self managedObjectModel];//获取实例
NSDictionary * entities = [model entitiesByName];//entitiesByName 得到所有的表的名字
NSEntityDescription * entity = [entities valueForKey:@"Student"];//从里面找出名为 Student 的表
数据库存放方式:NSPersistentStoreCoordinator
//使用 Core Data document 类型的应用程序,通常会从磁盘上的数据文中中读取或存储数据,这写底层的读写就由 Persistent Store Coordinator 来处理。一般我们无需与它直接打交道来读写文件,Managed Object Context 在背后已经为我们调用 Persistent Store Coordinator 做了这部分工作
数据库操作:NSManagedObjectContext 被管理的对象上下文(对数据直接操作)
//可以通过TA去访问底层的框架对象集合,这些对象集合统称为持久化堆栈(persistence stack)——它在应用程序和外部数据存储的对象之间提供访问通道
//Managed Object Context 的作用相当重要,对数据对象进行的操作都与它有关。当创建一个数据对象并插入 Managed Object Context 中,Managed Object Context 就开始跟踪这个数据对象的一切变动,并在合适的时候提供对 undo/redo 的支持,或调用 Persistent Store Coordinato 将变化保存到数据文件中去
//redo: 恢复已经提交的事务 undo: 回滚操作,支持读一致性,恢复失败的事务
//-executeFetchRequest: error: 执行 Fetch Request 并返回所有匹配的数据对象
NSFetchRequest * fetch = [[NSFetchRequest alloc] init];
NSArray * results = [context executeFetchRequest:fetch error:nil];
//获取NSManagedObjectContext的实例
//1.利用UIApplication代理获取
id delegate = [[UIApplication sharedApplication] delegate];
self.managedObjectContext = [delegate managedObjectContext];
//2.直接去创建实例
NSManagedObjectContext *context = [self managedObjectContext];//利用getter方法来获取
查询语句:NSPetchRequest 相当于select语句
//Fetch Requests 相当于一个查询语句,你必须指定要查询的 Entity。我们通过 Fetch Requests 向 Managed Object Context 查询符合条件的数据对象,以 NSArray 形式返回查询结果,如果我们没有设置任何查询条件,则返回该 Entity 的所有数据对象。我们可以使用谓词来设置查询条件,通常会将常用的 Fetch Requests 保存到 dictionary 以重复利用
NSPredicate * predicate = [NSPredicate predicateWithFormat:@"xx > %@", xx];//相当于select中的查询条件
NSSortDescriptor * sort = [[NSortDescriptor alloc] initWithKey:@"name"];//按照 name 来排序
NSArray * sortDescriptors = [NSArray arrayWithObject: sort];
// -setEntity: 设置你要查询的数据对象的类型(Entity)就是NSEntityDescription对象
// -setPredicate: 设置查询条件
// -setFetchLimit: 设置最大查询对象数目
// -setSortDescriptors: 设置查询结果的排序方法
// -setAffectedStores: 设置可以在哪些数据存储中查询
表格的记录:NSManagedObject Core Data存储的每个对象都继承自NSManagedObject,我们可以得到TA的一个实例,用这个实例去为表中的属性赋值
eg:
NSManagedObject *managedObject = [NSEntityDescription insertNewObjectForEntityForName:@"Student" inManagedObjectContext:managedObjectContext];
managedObject.name = @"like"; managedObject.age = 12;