工程日记之HelloSlide(3):如何使用Core Data数据库,以及和sqlite之间的对应关系

时间:2023-03-10 06:50:08
工程日记之HelloSlide(3):如何使用Core Data数据库,以及和sqlite之间的对应关系

Core Data 和 SQLite 是什么关系

core data是对sqlite的封装,因为sqlite是c语言的api,然而有人也需要obj-c的api,所以有了core data ,另外,core data不仅仅是把c的api翻译成oc的api,还提供了一些管理的功能,使用更加方便。

1. App升级之后数据库字段或者表有更改会导致crash,CoreData的版本管理和数据迁移变得非常有用,手动写sql语句操作还是麻烦一些。

2. CoreData不光能操纵SQLite,CoreData和iCloud的结合也很好,如果有这方面需求的话优先考虑CoreData。

3. CoreData并不是直接操纵数据库,比如:使用CoreData时不能设置数据库的主键,目前仍需要手动操作。

4. core data还有其他sql所不具备的优点,比如对undo的支持,多个context实现sketchbook类似的功能。为ManagedObject优化的row cash等

5. 另外core data是支持多线程的,但需要thread confinement的方式实现,使用了多线程之后可以最大化的防止阻塞主线程。

6. 效率上其实比较不出来感觉,因为手机程序的数据库比较小。

与SQLite中的对应关系

表格结构    --> NSEntityDescription  
数据库中所有表格和他们的联系 -->NSManagedObjectModel  
数据库存放方式 --> NSPersistentStoreCoordinator  
数据库操作 --> NSManagedObjectContext  
查询语句 --> NSFetchRequest  
表格的记录 --> NSManagedObject

NSEntityDescription

用来定义表格结构, 所以你就可以理解NSManagedObjectModel中的setEntities:(NSArray *)entities函数大概有什么用了 . 通常, 定义model, 是用文件CoreData.xcda*****odel, 可以图形化的操作. 这类似用nib来创建界面.

NSPersistentStoreCoordinator

这个类的对象通常用NSManagedObjectModel的对象来初始化, 这个类抽象出不同的存放方式, 最经常用的是NSSQLiteStoreType.  也就是一个负责把数据库存起来的引擎。

NSManagedObjectContext

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

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

怎么查看底层的Sqlite数据库

https://blog.csdn.net/xiliang_honst/article/details/7862153 

func ifExists(instanceid id:Int)->Bool{
let app = UIApplication.shared.delegate as! AppDelegate
let context = app.persistentContainer.viewContext //声明数据的请求
let fetchRequest = NSFetchRequest<Composing>(entityName:"Composing")
//fetchRequest.fetchLimit = 10 //限定查询结果的数量
fetchRequest.fetchOffset = //查询的偏移量 //设置查询条件
let requestString:String = "composingid = \(id)"
let predicate = NSPredicate(format: requestString, "")
fetchRequest.predicate = predicate //查询操作
do {
let fetchedObjects = try context.fetch(fetchRequest)
if(fetchedObjects.count == ){
return false
}
else{
return true
} }
catch {
fatalError("查询失败:\(error)")
}
}

Core Data怎么支持多线程?