做Android應(yīng)用,不可避免的會(huì)與SQLite打交道。隨著應(yīng)用的不斷升級(jí),原有的數(shù)據(jù)庫(kù)結(jié)構(gòu)可能已經(jīng)不再適應(yīng)新的功能,這時(shí)候,就需要對(duì)SQLite數(shù)據(jù)庫(kù)的結(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í)行如下語(yǔ)句來實(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) NOT NULL ,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ù)庫(kù)結(jié)構(gòu)向新數(shù)據(jù)庫(kù)結(jié)構(gòu)的遷移,并且其中還可以保證數(shù)據(jù)不會(huì)應(yīng)為升級(jí)而流失。
當(dāng)然,如果遇到減少字段的情況,也可以通過創(chuàng)建臨時(shí)表的方式來實(shí)現(xiàn)。