CoreData 与 SQLite 比较

CoreData.framework : iOS中提供了对原始sqlite数据库API访问的封装,通过这个framework来管理数据缓存和持久数据要比使用sql语句操作sqlite数据库简单和方便许多。

机制:通过framework来存储和查询数据只需要使用framework提供的类就可以,你可以完全使用对象的形式来管理你的数据以及数据之间的关系,framework已经很好地将数据库表和字段封装成了对象和属性,表之间的一对多、多对多关系则封装成了对象之间的包含关系.

通过 relationship 来表示:

一对多时:设置为 properties 项选中 Optional,Plural 选项 To-Many Relationship 选中;

多对一反向关系时:properties 项选中 Optional,Count 项选中Minimun 和 Maximun 并分别设置其值为1;

Core Data 特点:

1)Core Data的强大之处就在于这种关系可以在一个对象更新时,其关联的对象也会随着更新,相当于你更新一张表的时候,其关联的其他表也会随着更新。

2)Core Data的另外一个特点就是提供了更简单的性能管理机制,例如,使用NSFetchedResultsController类,你不用使用sql的Limit而是使用NSFetchRequest类的setFetchBatchSize()就可以限制查询记录的总数,而NSFetchedResultsController类神奇的地方在于需要获取更多记录的时候,这个类会自动更新其缓存。

3) 对于多表查询上相对来说,CoreData没有 sql 直观,但CoreData功能还是可以完成相关操作的。

但是对于类似外连接,左连接等操作,在CoreData中就显得无力。

相关文章

安装 在Windows上安装SQLite。 访问官网下载下Precompliled Binaries for Windows的两个压缩包。 创建s...
一、安装 下载地址:http://www.sqlite.org/download.html 将Precompiled Binaries for Windows下的包下...
实例: 会员信息管理 功能:1.查看数据库 2.清空数据库 3.增加会员 4.删除会员 5.更新会员 6.查找会员  ...
关于SQLite SQLite是一个轻量的、跨平台的、开源的数据库引擎,它的在读写效率、消耗总量、延迟时间和整...