項目中經常會用到數據的存儲,關于小量數據的存儲,和海量數據的存儲這里不做討論,本帖主要討論的是10000條以內數據的管理問題。 關于持久化存儲,無外乎CoreData和sqllite兩種。但個人一直對CoreData不太感冒,因此選擇的是sqllite。
本文主要介紹理論方面的部分,實現代碼可參考 https://github.com/TonyJR/TODBModel
我們首先把應用分為三層,應用層、數據層、持久層。我們重點實現數據層部分。
應用層主要是對數據的調用,展示數據修改界面數據層就是指的Model和ModelManager持久層包括所有的數據庫操作,為了不重復造輪子,數據庫的讀寫我們使用FMDB
如圖所示,為保證讀寫速度,應用層只對數據層進行讀寫。 一般情況下,數據層只對持久層進行寫入,只有初始化數據時,才會從持久層讀取。
數據的唯一性
客戶端的數據一般來源于服務器,在不同界面中,可能需要對同一對象進行操作。比如通訊錄列表和聯系人詳情兩個界面,可能同時持有同一個聯系人對象。當編輯聯系人信息并修改時,兩個界面都應該發生變化。 那么我們需要使用ModelManager來保證內存中關于同一id的對象不會多次出現。
自動化建表、屬性糾正
通過runtime可以方便的讀取模型所有屬性及其類型。因此我們可以在初始化模型的時候,檢查數據表是否存在,并自動生成sql語句創建表格。NSMutableDictionary *dic = [NSMutableDictionary dictionary];unsigned int count;objc_PRoperty_t *propertys = class_copyPropertyList([self class], &count);for (int i = 0; i < count; i++){ objc_property_t property = propertys[i]; const char *name = property_getName(property); const char *type = property_copyAttributeValue(property,"T"); NSString *sqlTypeName = objcType2SqlType(type); if (!sqlTypeName) { NSLog(@"#TOModel# %@中存在未識別的數據類型%s",NSStringFromClass([self class]),type); }else{ [dic setObject:sqlTypeName forKey:[NSString stringWithUTF8String:name]]; }}另外開發過程中,模型隨時可能增加或者刪除字段,我們需要在模型加載過程中檢查模型的屬性變化并修改表格。本文作者目前正在找工作,歡迎內推 mail: show_3@163.com
新聞熱點
疑難解答