看板 AndroidDev 關於我們 聯絡資訊
※ 引述《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