※ 引述《bluesnow4425 (殘)》之銘言:
: 我在開發的APP含有一些資料 現在我面臨一個難題
: 我一開始開發的時候是直接用xml來寫(比較省時)
: 但是因為有些資料上是關聯的 所以我一直很猶豫要換成sqlite
: 但是我稍微看了sqlite的介紹
: 發現他當然不如sql或mysql這麼方便
: 主要問題在於sqlite似乎沒辦法刪除欄位
: 而我的功能又包含需要使用者可能需要常常新增一個"只屬於一筆資料的欄位"
: 比如說A資料具有"形狀"屬性 但B~Z資料並不需要
: 諸如此類的情形(但A~Z資料還是具有一些共同屬性)
: 而使用者可能也需要把"形狀"這個屬性刪掉...
: 這時候我就得把整個資料表drop掉(因為sqlite好像只能整個drop建一個新的?)
: 當然也可以為每筆資料新建一個資料表 但這樣太不實際了
: 而且每次顯示都得抓出兩個表
: 當然XML的問題就是速度比較慢
: 還要避免流水號的錯誤(資料庫因為有ID屬性應該比較沒有這個問題)
: 不過我的資料都有避免使用三層以上的結構
: 盡量以屬性來代替
: 請問這樣的狀況我還要改用sqlite嗎?
如果你的目的主要是想要將儲存資料由xml移入database,
而且資料沒有多到上萬筆的話。
我有個想法你可以參考看看,
1.設計table的欄位為 _id, special_attrs 兩欄。
2.程式開始時將全部資料由database讀出,並建構成你定義的資料結構(ex..Data)
那麼你的全部資料會是Data array,
這邊的重點在於special_attrs 欄位裡的值是使用 key=value,key=value,...的方式儲存字串
因此取出此欄位後字串,將其parser放入Map<String(key),String(value)>並存放於你的資料結構(Data)中,
你就可以使用map.containsKey(String key)來判斷此data是否有key屬性
以及使用map.get(String key)來取出key屬性的value。
3.儲存到database時則要將map裡的資料取出並排成key=value,key=value,...的格式存入。
當然這只是一個概念,你可以視情況調整,
例如table的欄位為 _id, common_attr1, common_attr2,... , special_attrs
又或你的value並不都是String,則Map<String,String>可改為Map<String,Object>,取值後在casting,
供你參考看看。
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 114.136.71.197