zoukankan      html  css  js  c++  java
  • core data 类比,

    转:http://java-mans.iteye.com/blog/1648600

    这个过程出现了, 表格的结构(schema), 所有表格的结构和相互联系构成整个数据库的模型, 数据库存放的方式(可以是文件或者在内存), 数据库操作, sql语句(主要是查询), 表格里面的记录
    下面将上面说的文字, 跟CoreData的类作个对应:
    表格结构 --> NSEntityDescription
    数据库中所有表格和他们的联系 -->NSManagedObjectModel
    数据库存放方式 --> NSPersistentStoreCoordinator
    数据库操作 --> NSManagedObjectContext
    查询语句 --> NSFetchRequest
    表格的记录 --> NSManagedObject

    可能上面的对应关系并非十分严格, 但确实可以帮助理解.
    NSEntityDescription用来定义表格结构, 所以你就可以理解NSManagedObjectModel中的setEntities:(NSArray *)entities函数大概有什么用了 . 通常, 定义model, 是用文件CoreData.xcdatamodel, 可以图形化的操作.

    NSPersistentStoreCoordinator
    这个类的对象通常用NSManagedObjectModel的对象来初始化, 这个类抽象出不同的存放方式, 最经常用的是NSSQLiteStoreType.

    NSManagedObjectContext
    这个类的对象又用NSPersistentStoreCoordinator的对象来初始化, 它里面有些方法来添加, 删除NSManagedObject

    NSFetchRequest
    通常用NSEntityDescription来构造查询, 也就指定查询那个表格, 另外可以指定排序.

    在CoreData的设计中, 下一层有相应的属性指向上一层, 所以NSManagedObject有属性得到NSEntityDescription, NSEntityDescription有属性得到NSManagedObjectModel.

    NSFetchedResultsController, 只是又封了一下, 和NSFetchRequest合起来使用, 方便取数据, 另外和NSManagedObjectContext关联, 当数据库发生变化的时候收到通知.

  • 相关阅读:
    创建你的 /proc 文件
    在 /proc 里实现文件
    使用 /proc 文件系统
    printk函数速率限制
    printk函数打开和关闭消息
    printk 函数消息是如何记录的
    mysql存储程序
    Javascript 笔记与总结(1-1)作用域
    Java实现 LeetCode 142 环形链表 II(二)
    Java实现 LeetCode 142 环形链表 II(二)
  • 原文地址:https://www.cnblogs.com/guligei/p/3478818.html
Copyright © 2011-2022 走看看