• 【CoreData】表之间的关联


    这次是表之间怎么进行关联,要求如下:
    // 建立学生与班级表之间的联系
    既然是表与表之间的关联,那肯定是要先创建表:

    // 1.创建模型文件 (相当于一个数据库里的表)

    // New File ———— CoreData ———— Data Model ———— Next【CoreData】1.简单地使用


    // 2.添加实体 (相当于一张表)

    // 找到我们创建的模型文件(xxx.xcdatamodeld,我创建的叫School.xcdatamodeld————Add Entity ———— 添加表内属性(这边我添加2个属性(name,age))


    【CoreData】1.简单地使用

    //3.在此模型文件内我们再添加第二张表Classes,表内的属性(这边我添加一个属性(classname,classNo))


    【CoreData】表之间的关联

     

    // 4.因为学生肯定是属于某个班级的,所以我们选择学生的表,在表中的Relationships内添加关联。


    【CoreData】表之间的关联
    // 5.添加完关联后我们就需要创建实体了,在创建的过程中,我们会看到school内有2张表(student,classes),因为classes是没有关联任何表的(student则关联依赖classes表),所以先创建classes实体,再创建student的实体。

    // New File ———— CorData ———— NSManagedobject subclass ————Next(记得选择需要关联的表)这样就会自动生成相应的模型

    // 5.1先关联classes表

    【CoreData】表之间的关联

    // 5.2再关联student表

    【CoreData】表之间的关联

    // 5.3生成以下相应模型



    // 6.生成上下文 关联模型文件生成数据库(关联的时候,如果本地没有数据库文件,CoreData会自己创建)

    // 上下文,记得引用CoreData框架

        NSManagedObjectContext *context= [[NSManagedObjectContext alloc]init];

    // 上下文关联数据库

    // model模型文件参数:mergedModelFromBundles:因为模型文件是资源文件,所以会放到BUNDLES里面,所以只需要写nil就可以了。

        NSManagedObjectModel *model= [NSManagedObjectModel mergedModelFromBundles:nil];

    // 持久化存储调度器(持久化:把数据保存在一个文件,而不是放在内存中)

        NSPersistentStoreCoordinator *store=[[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:model];

    // 告诉CoreData数据库的名字和路径

        NSString *doc= [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];

        

        NSString *sqlitePath=[doc stringByAppendingPathComponent:@"School.sqlite"];

        [store addPersistentStoreWithType:NSSQLiteStoreTypeconfiguration:nil URL:[NSURL fileURLWithPath:sqlitePath] options:nilerror:nil];

        

        context.persistentStoreCoordinator =store;


    然后我们来测试一下

    #pragma mark - 添加

    - (void)addStudent

    {

       // 创建两个班级一班,二班

       Classes*oneClass= [NSEntityDescriptioninsertNewObjectForEntityForName:@"Classes"inManagedObjectContext:_context];

        oneClass.classname= @"一班";

        oneClass.classNo= @(1.0);

        

       Classes*twoClass= [NSEntityDescriptioninsertNewObjectForEntityForName:@"Classes"inManagedObjectContext:_context];

        twoClass.classname= @"二班";

        twoClass.classNo= @(2.0);

        

       // 创建两个学生对象

       Student*zhangsan= [NSEntityDescriptioninsertNewObjectForEntityForName:@"Student"inManagedObjectContext:_context];

        zhangsan.name= @"张三";

        zhangsan.age= @(1.80);

        zhangsan.classNo= oneClass;

        

       Student*lisi= [NSEntityDescriptioninsertNewObjectForEntityForName:@"Student"inManagedObjectContext:_context];

        lisi.name= @"李四";

        lisi.age= @(2.10);

        lisi.classNo= twoClass;

        

       // 直接保存数据库

        [_contextsave:nil];

        

    }


    #pragma mark - 读取

    - (void)readStudent

    {

       // 只读取二班的学生

        

       // 1.FectchRequest 抓取请求对象

       NSFetchRequest *request= [NSFetchRequest fetchRequestWithEntityName:@"Student"];

        

       // 2.设置过滤条件

       //这边直接使用点语法就可以了

       NSPredicate*pre= [NSPredicatepredicateWithFormat:@"classNo.classname= %@",@"二班"];

        request.predicate= pre;

        

       // 4.执行请求

        NSArray*stus = [_contextexecuteFetchRequest:requesterror:nil];

        

        for(Student*stu instus)

        {

           NSLog(@"名字:%@班级:%@",stu.name,stu.classNo.classname);

        }

        

    }


    2015-10-29 22:09:06.519 CoreData表之间的关联[1817:76617]名字:李四班级:二班

    2015-10-29 22:09:06.519 CoreData表之间的关联[1817:76617]名字:李四班级:二班

     

    2015-10-29 22:09:06.519 CoreData表之间的关联[1817:76617]名字:李四班级:二班


    好了,以上就是CoreData表之间的关联,分页等操作。会陆续更新!【CoreData】1.简单地使用

    DEMO下载地址:链接: http://pan.baidu.com/s/1qWtJgw0 密码: wpaa

    如果哪里有错或者有什么问题可以随时联系我,转载请注明出处,谢谢!
  • 相关阅读:
    3-8
    3-7
    3-5
    3-4
    3-3
    3-2
    3-1
    2-11
    2-10
    2-9
  • 原文地址:https://www.cnblogs.com/miaomiaoshen/p/5188642.html
Copyright © 2020-2023  润新知