Swift利用CoreData實現(xiàn)一個上班簽到的小工具
前言
我們在之前的兩篇里面實現(xiàn)了一個十分簡陋的通訊錄,而且都是通過系統(tǒng)默認(rèn)的方式創(chuàng)建的CoreData??墒菍嶋H中哪里有那么好的事情嘛,要是忘記在創(chuàng)建工程的時候勾選了下面這個圖怎么辦?
難道我們要把工程刪除,再重新創(chuàng)建嘛?很多時候再開始工程的時候并特么的不知道需要用到數(shù)據(jù)庫啊。更多的時候已經(jīng)都開始敲代碼了,連需求文檔都還木有拿到手里,PM只會輕輕的說一句:設(shè)計圖不是已經(jīng)有了嘛,先畫UI吧。
所以,CoreData Stack是為了解決這個問題誕生的嘛?很遺憾,并不是。看了前面的兩篇文章之后,有木有覺得CoreData不怎么好用,還挺麻煩的吶?這時候要祭出CoreData Stack的啦。
1. CoreData Stack的作用
其實這個東西在一篇的時候提到過,不信您看:Swift實踐:使用CoreData完成一個通訊錄存儲
一個基本的 Core Data 棧由四個主要部分組成:托管對象 (NSManagedObject),托管對象上下文 (NSManagedObjectContext),持久化存儲協(xié)調(diào)器 (NSPersistentStoreCoordinator),以及持久化存儲 (NSPersistentStore)。
CoreDataStack,是自定義的一個CoreData 的棧對象,可以通過它,初始化項目的CoreData,以及獲取到Context,對數(shù)據(jù)庫進(jìn)行增刪改查等操作。
2.創(chuàng)建 CoreData Stack
非典型技術(shù)宅既然說了這貨有四部分組成,那咱們就一個一個來唄。艾瑪,因為發(fā)現(xiàn)文章會被抄襲,抄襲之后有些人還不署名,搞的只好在文章里面內(nèi)嵌入一些自己的名字。心酸~~~~
2.1 iOS9
在iOS9中,CoreData Stack的三個核心類是這樣的:
-管理對象上下文NSManagedObjectContext
- 對象模型NSManagedObjectModel
- 存儲調(diào)度器NSPersistentStoreCoordinator
這個時候存儲是在Documents中間。
2.2 iOS10之后
iOS10之后就有點(diǎn)不一樣了, 增加了一個叫做NSPersistentContainer的東西。這個玩意兒作用就是用來管理CoreData Stack,為了能夠讓大家用起來更爽、更簡單。
需要說明的是,NSPersistentContainer 一點(diǎn)都沒有向下兼容的意思,完全不兼容iOS9.0,如果非要在iOS9.0里面使用,會直接閃退。
這個時候存儲是在Library->Application Support中。
2.3 來吧,開始創(chuàng)建吧
宅胖這么懶,怎么還可能再寫一個兼容iOS9.0的吶,想太多了~~~哈哈!所以,俺們只寫iOS10.0以后的。寫到這個時候,連版本號都已經(jīng)寫煩了。
- Step1:搞一個NSPersistentContainer出來
- Step2:創(chuàng)建CoreData Stack
- Step3:別忘了還有一個NSManagedObjectContext
- Step4:提供一個保存數(shù)據(jù)的方法
- Step5:最后別忘記了在AppDelegate.swift里面應(yīng)用一下,不然不是白搞了半天嘛
lazy var storeContainer: NSPersistentContainer = { let container = NSPersistentContainer(name: self.modelName) container.loadPersistentStores(completionHandler: { (storeDescription, error) in if let error = error as NSError? { debugPrint("Unclear error\(error)") } }) return container }() lazy var managedContext: NSManagedObjectContext = { return self.storeContainer.viewContext }() func saveContext() { guard managedContext.hasChanges else { return } do { try managedContext.save() } catch let error as NSError { debugPrint("Unclear error\(error)") } }
3. 一對多的關(guān)系
CoreData中實體管理關(guān)系是有三種的:1V1,1VN,NVN。咱們之前的兩個例子都是1V1。但是這個跟生活中不符啊,注意 例如一個人下了很多訂單,訂單里面又包含了很多商品。
如圖所示,Relationships表示管理關(guān)系的名稱,Destination表示目標(biāo)表的名字,Inverse表示反向關(guān)系。
前面兩個都比較好理解,Inverse需要稍微多說一點(diǎn)點(diǎn)。如果沒有反向關(guān)系,就選擇No Inverse,但是蘋果官方建議為了保證數(shù)據(jù)之間的一致性,最好設(shè)置反向關(guān)系。
4. 完成Demo,了解使用CoreData Stack
然后咱們搞個小型本地化純良心自覺單機(jī)版的打卡器。這個打卡器用來管理員工的每次打卡時間??梢栽黾印h除打卡時間。
完成后的效果圖:
思維導(dǎo)圖如下:
4. 補(bǔ)充:如果創(chuàng)建工程的時候遺忘了勾選使用CoreData怎么辦
如果忘選了也沒有關(guān)系,創(chuàng)建一個新的Data Model文件:
設(shè)置完數(shù)據(jù)庫之后,按照如下操作:
好啦,就會自動生成文件啦。
所有的源代碼都在這里:
github地址:https://github.com/Stanbai/CoreDataDemo.git
源碼下載:http://xiazai.jb51.net/201712/yuanma/CoreDataDemo(jb51.net).rar
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
openstack重啟swift服務(wù)后報錯問題解決方案
這篇文章主要介紹了解決openstack重啟swift服務(wù)后報錯,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08Swift仿選擇電影票的效果并實現(xiàn)無限/自動輪播的方法
這篇文章主要給大家介紹了關(guān)于Swift仿選擇電影票的效果并實現(xiàn)無限/自動輪播的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08如何在Swift?中使用?async?let?并發(fā)運(yùn)行后臺任務(wù)
Swift?異步編程是一種編寫允許某些任務(wù)并發(fā)運(yùn)行而不是按順序運(yùn)行的代碼的方法,這篇文章主要介紹了在Swift中使用async?let并發(fā)運(yùn)行后臺任務(wù),需要的朋友可以參考下2023-06-06Swift TableView實現(xiàn)凍結(jié)窗格功能
這篇文章主要為大家詳細(xì)介紹了Swift TableView實現(xiàn)凍結(jié)窗格功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11Swift 中如何使用 Option Pattern 改善可選項的 API 設(shè)計
這篇文章主要介紹了Swift 中如何使用 Option Pattern 改善可選項的 API 設(shè)計,幫助大家更好的進(jìn)行ios開發(fā),感興趣的朋友可以了解下2020-10-10