Android數(shù)據(jù)庫升級(jí)實(shí)例
第一部分
Andoird的SQLiteOpenHelper類中有一個(gè)onUpgrade方法。幫助文檔中只是說當(dāng)數(shù)據(jù)庫升級(jí)時(shí)該方法被觸發(fā)。經(jīng)過實(shí)踐,解決了我一連串的疑問:
1. 幫助文檔里說的“數(shù)據(jù)庫升級(jí)”是指什么?
你開發(fā)了一個(gè)程序,當(dāng)前是1.0版本。該程序用到了數(shù)據(jù)庫。到1.1版本時(shí),你在數(shù)據(jù)庫的某個(gè)表中增加了一個(gè)字段。那么軟件1.0版本用的數(shù)據(jù)庫在軟件1.1版本就要被升級(jí)了。
2. 數(shù)據(jù)庫升級(jí)應(yīng)該注意什么?
軟件的1.0版本升級(jí)到1.1版本時(shí),老的數(shù)據(jù)不能丟。那么在1.1版本的程序中就要有地方能夠檢測(cè)出來新的軟件版本與老的數(shù)據(jù)庫不兼容,并且能夠有辦法 把1.0軟件的數(shù)據(jù)庫升級(jí)到1.1軟件能夠使用的數(shù)據(jù)庫。換句話說,要在1.0軟件的數(shù)據(jù)庫的那個(gè)表中增加那個(gè)字段,并賦予這個(gè)字段默認(rèn)值。
3. 程序如何知道數(shù)據(jù)庫需要升級(jí)?
SQLiteOpenHelper類的構(gòu)造函數(shù)有一個(gè)參數(shù)是int version,它的意思就是指數(shù)據(jù)庫版本號(hào)。比如在軟件1.0版本中,我們使用SQLiteOpenHelper訪問數(shù)據(jù)庫時(shí),該參數(shù)為1,那么數(shù)據(jù)庫版本號(hào)1就會(huì)寫在我們的數(shù)據(jù)庫中。
到了1.1版本,我們的數(shù)據(jù)庫需要發(fā)生變化,那么我們1.1版本的程序中就要使用一個(gè)大于1的整數(shù)來構(gòu)造SQLiteOpenHelper類,用于訪問新的數(shù)據(jù)庫,比如2。
當(dāng)我們的1.1新程序讀取1.0版本的老數(shù)據(jù)庫時(shí),就發(fā)現(xiàn)老數(shù)據(jù)庫里存儲(chǔ)的數(shù)據(jù)庫版本是1,而我們新程序訪問它時(shí)填的版本號(hào)為2,系統(tǒng)就知道數(shù)據(jù)庫需要升級(jí)。
4. 何時(shí)觸發(fā)數(shù)據(jù)庫升級(jí)?如何升級(jí)?
當(dāng)系統(tǒng)在構(gòu)造SQLiteOpenHelper類的對(duì)象時(shí),如果發(fā)現(xiàn)版本號(hào)不一樣,就會(huì)自動(dòng)調(diào)用onUpgrade函數(shù),讓你在這里對(duì)數(shù)據(jù)庫進(jìn)行升級(jí)。根據(jù)上述場(chǎng)景,在這個(gè)函數(shù)中把老版本數(shù)據(jù)庫的相應(yīng)表中增加字段,并給每條記錄增加默認(rèn)值即可。
新版本號(hào)和老版本號(hào)都會(huì)作為onUpgrade函數(shù)的參數(shù)傳進(jìn)來,便于開發(fā)者知道數(shù)據(jù)庫應(yīng)該從哪個(gè)版本升級(jí)到哪個(gè)版本。
升級(jí)完成后,數(shù)據(jù)庫會(huì)自動(dòng)存儲(chǔ)最新的版本號(hào)為當(dāng)前數(shù)據(jù)庫版本號(hào)。
參考:StackOverFlow對(duì)“數(shù)據(jù)庫版本在數(shù)據(jù)庫中的存儲(chǔ)位置”的問答。
第二部分做Android應(yīng)用,不可避免的會(huì)與SQLite打交道。隨著應(yīng)用的不斷升級(jí),原有的數(shù)據(jù)庫結(jié)構(gòu)可能已經(jīng)不再適應(yīng)新的功能,這時(shí)候,就需要對(duì) SQLite數(shù)據(jù)庫的結(jié)構(gòu)進(jìn)行升級(jí)了。 SQLite提供了ALTER TABLE命令,允許用戶重命名或添加新的字段到已有表中,但是不能從表中刪除字段。
并且只能在表的末尾添加字段,比如,為 Subscription添加兩個(gè)字段:
1 ALTER TABLE Subscription ADD COLUMN Activation BLOB;
2 ALTER TABLE Subscription ADD COLUMN Key BLOB;
另外,如果遇到復(fù)雜的修改操作,比如在修改的同時(shí),需要進(jìn)行數(shù)據(jù)的轉(zhuǎn)移,那么可以采取在一個(gè)事務(wù)中執(zhí)行如下語句來實(shí)現(xiàn)修改表的需求。
1. 將表名改為臨時(shí)表
ALTER TABLE Subscription RENAME TO __temp__Subscription;
2. 創(chuàng)建新表
CREATE TABLE Subscription (OrderId VARCHAR(32) PRIMARY KEY ,UserName VARCHAR(32) NOTNULL ,ProductId VARCHAR(16) NOT NULL);
3. 導(dǎo)入數(shù)據(jù)
INSERT INTO Subscription SELECT OrderId, “”, ProductId FROM __temp__Subscription;
或者
INSERT INTO Subscription() SELECT OrderId, “”, ProductId FROM __temp__Subscription;
* 注意 雙引號(hào)”” 是用來補(bǔ)充原來不存在的數(shù)據(jù)的
4. 刪除臨時(shí)表
DROP TABLE __temp__Subscription;
通過以上四個(gè)步驟,就可以完成舊數(shù)據(jù)庫結(jié)構(gòu)向新數(shù)據(jù)庫結(jié)構(gòu)的遷移,并且其中還可以保證數(shù)據(jù)不會(huì)應(yīng)為升級(jí)而流失。
當(dāng)然,如果遇到減少字段的情況,也可以通過創(chuàng)建臨時(shí)表的方式來實(shí)現(xiàn)。
posted on 2014-11-14 10:03 順其自然EVO 閱讀(642) 評(píng)論(0) 編輯 收藏 所屬分類: android