CoreData 多表 关联

本文转载至 http://www.jianshu.com/p/e9f3b5e0cd19

1.概念简介

    coreData中存在复杂的数据关系时,一张表难以满足需求,此时就需要了解使用coreData多表的关联使用.

    如 课程表 和 章节表 的关系:一个课程跟章节的对应关系是 一对多,单一个章节只能对应一个课程; 而课程表 与 讲师表 之间的关系:一个课程可以有多个讲师,一个讲师也可以讲多个课程,他们之间是多对多的关系 .

    表之间就是靠这种相互约束的关系建立关联.

    假设要删除一个课程,与此课程相关联的章节是否删除;或者说删除一个章节,这个章节对应的课程是否删除.这个就涉及到多表操作,设置表之间的级联关系.接下来以coreData设置一一讲解

2.coreData 相关设置简介

1)删除关系


删除关系设置

A.ab->B :A对象指向B的删除关系ab被设置为:

No Action:当A被删除时,B对象不变,但会指向一个不存在的对象,一般不建议使用;

Nullify(作废):当A对象被删除时,B对象指向的A对象会置为空,如果A与B的关系式一对多,则是A对象从B容器中移除

Cascade(级联):当A对象被删除时,A对象指向的B对象也会被删除;

Deny(拒绝):当删除指向对象B存在的A对象时,操作将会被拒绝;

如:Course_Section: Cascade , 删除Course时,与Course相关联的Section都会被删除;

    Section_Course: Nullify , 删除Section时,与Section相关的Course不会被删除;

2)对象对应关系


对象对应关系

A.ab->B :A对象指向B的对应关系ab被设置为:

To Many: 表示一个A对象可以包含多个B对象;

To One: 表示一个A对象只能对应一个B对象;

如:Course_Section: To Many , 一门Course可以包含多个Section;

    Section_Course: To One ,一个Section只能指向一门Course;

所以Course与Section的关系是 1:N (1对多)

如:Course_Teacher: To Many , 一门Course可以包含多位Teacher;

    Teacher_Course: To Many ,一位Teacher可以指向多门Course;

所以Course与Section的关系是 M:N (多对多)

3.多表创建流程 

1)先创建需要的实体表(方法见"CoreData单表创建使用")


Course, Section, Teacher 表

2)建立关联 设置删除关系,对应关系如下(设置的具体含义已在文章第二部分介绍)


课程_教师 (一课程可包含多个教师,删除关系:作废)

 


课程_章节(一节课可包含多个章节,删除关系:级联)

 


章节_课程(一个章节只属于一个课程,删除关系:作废)

 


教师_课程(一个教师可以讲多门课,删除关系:作废)

创建之后查看style关系:


表关系

 

3)使用创建的对象生成相应地文件:.h和.m(方法见"CoreData单表创建使用")


根据3个对象创建的文件

    根据设置的对象之间的对应关系 会生成相应地属性和方法


Section对应一个课程时 添加课程对象的属性

课程对应的章节以及教师都是多个,生成NSSet 存储 并生成相应方法

NSSet 是一个无序的集合 ,可以使用NSSet 与NSArray根据需要转换使用,其他使用方法 同单表使用的增删查改,只是访问时多层访问.

如:NSPredicate*predict = [NSPredicate predicateWithFormat:@"section_course.courseId = %d",courseId];

如:self.courseEntity.course_teacher.count

........................................................................................................................................

coreData多表关联的基本操作已做一个简单的介绍,具体的功能还待使用者发掘,并且苹果提供了NSFetchController 与coreData结合使用,具体情节,还待下次分享......(欢迎批评指正~~)

posted @ 2015-12-22 11:25  天牛  阅读(317)  评论(0编辑  收藏  举报