前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >iOS中CoreData数据管理系列一——初识CoreData

iOS中CoreData数据管理系列一——初识CoreData

作者头像
珲少
发布2018-08-15 17:10:46
7820
发布2018-08-15 17:10:46
举报
文章被收录于专栏:一“技”之长一“技”之长

iOS中CoreData数据管理系列一——初识CoreData

一、何为CoreData

    CoreData是一个专门用来管理数据的框架,其在性能与书写方便上都有很大的优势,在数据库管理方面,apple强烈推荐开发者使用CoreData框架,在apple的官方文档中称,使用CoreData框架可以减少开发者50%——70%的代码量,这虽然有些夸张,但由此可见,CoreData的确十分强大。

二、设计数据模型

    在iOS开发中,时常使用SQL数据库对大量的表结构数据进行处理,但是SQL有一个十分明显的缺陷,对于常规数据模型的表,其处理起来是没问题的,例如一个班级表,其中每条数据中有班级名称,人数这样的属性,一个学生表,其中每条数据有学生的姓名,性别,年龄这样的属性。但是如果要在表与表之间建立联系,自定义对象与自定义对象之间产生从属关系,使用SQL处理起来就十分麻烦了,例如如果这个班级表中有一个班长的属性,这个属性是一个学生类型。关于iOS中SQL的使用相关博客,地址如下:

Sqlite数据库相关知识:http://my.oschina.net/u/2340880/blog/600820

iOS中sqlite3框架的使用和封装:http://my.oschina.net/u/2340880/blog/601802

    CoreData的一大优势即是其可以方便的在对象之间建立关系。

1.创建实体类型及其属性

    使用Xcode创建一个工程,在工程中新建一个文件,选择Core Data分类中的DataModel创建,如下图:

这时在Xcode的文件导航区会出现一个以xcdatamodeld为扩展名的文件,这个文件就是数据模型文件,点击Add Entity按钮添加一个实体类型,取名为SchoolClass,为这个类型添加两个属性,分别为名字name和学生数量stuNum,如下图:

2.对实体类型进行设置

    在Xcode右侧的工具栏中可以对实体类型进行一些设置,选中一个实体类型,如下图:

Name设置实体类型的名称,Abstract Entity设置是否是抽象实体,如果勾选,则此实体不能被实例化,只能被继承,类似于抽象类,比如定义人为一个实体类型,在定义继承于人实体类型的老师、学生等来进行实例化。Parent Entity用来选择父类实体,Class用于设置对应的类的。

3.在实体对象之间建立关系

    再创建一个学生类实体Student,添加name和age两个属性。选中SchoolClass,在其中的Relationships模块中点击+号,来添加一个关系,如下图:

这时,SchoolClass实体类型中就有了一个Student类型的班长属性。如果切换一下编辑风格,可以更加清晰的看到实体类型之间的关系,如下图:

4.对属性和关系进行设置

    选中一个属性或者关系,在右侧的工具栏中可以对属性进行一些设置,如下图:

name设置属性的名字,Optional类型代表可选,即在实例化对象时可以赋值也可以不赋值。Attribute设置属性的数据类型,Default Value设置数据的默认值。

专注技术,热爱生活,交流技术,也做朋友。 ——珲少

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016/01/27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • iOS中CoreData数据管理系列一——初识CoreData
    • 一、何为CoreData
      • 二、设计数据模型
        • 1.创建实体类型及其属性
        • 2.对实体类型进行设置
        • 3.在实体对象之间建立关系
        • 4.对属性和关系进行设置
    相关产品与服务
    数据库
    云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档