ios中SQLite的重构封装

IOS开发

  1. Controller中的UI层
  2. Controller中的Model层
  3. 服务层(去连接Model跟数据库的中间层)
  4. 数据库层(Sqlite,XML,JSON)
  5. 网络服务器层(包括WebService跟Web数据库,如MySQL或者Oracle)

C/S分层结构

IOS中CoreData VS SQLite

CoreData

  • CoreData说实话是一个对如SQLite这样的嵌入式数据库做面向对象的处理
  • CoreData不是一个数据库
  • CoreData只是一个操作数据库的核心框架

CoreData术语中借鉴了Sqlite

SQLite中的外键约束

CREATE TABLE "t_person" (name text,age integer,height real,id integer PRIMARY KEY,“book_id” integer REFERENCESt_book(id) ON DELETE CASCADE)

这段话的解析是:

  • 创建一个t_person的表(里面有id,name,height这3个基本属性),还有一个book_id的属性是连接REFERENCESt_book这个表的(id)属性,t_book中id对应删除选项是CASCADE

  • 删除选项是CASCADE这个字段告诉我们当删除t_book中id=2的那行,那么t_person中book_id等于2那些行都要
    对应删除

    • 删除选项除了CASCADE还有 SetNull,SetDefault,Restrict
    • SetNull就是当删除t_book中id=2的那行,那么t_person中book_id等于2那些行的book_id都设置为Null
    • SetDefault就是当删除t_book中id=2的那行,那么t_person中book_id等于2那些行的book_id都不变
    • Restrict限制删除,哪一行都不可以被删除

CoreData中实体的Relationship

  • 打开CoreData项目的以xcdatamodeld结尾的文件(就是 数据模型管理文件)

  • 在此输入图片描述

    • 不过跟SQLite不一样的是,CoreData绑定的关系,设定的删除选项的以对象与对象之间
    • 而SQLite两个表(对应CoreData的Managerobject)的关系绑定是以对象的属性与属性之间


挖坑

2014年4月24日

晚上再补上,重构的

2014年4月25日

CoreData的并发跟与RestAPI的作用

你可能感兴趣的:(ios,coredata)