基于A(yíng)ndroid SQLite的升級(jí)詳解
做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命令,允許用戶(hù)重命名或添加新的字段到已有表中,但是不能從表中刪除字段。
并且只能在表的末尾添加字段,比如,為 Subscription添加兩個(gè)字段:
ALTER TABLE Subscription ADD COLUMN Activation BLOB;
ALTER TABLE Subscription ADD COLUMN Key BLOB;
另外,如果遇到復(fù)雜的修改操作,比如在修改的同時(shí),需要進(jìn)行數(shù)據(jù)的轉(zhuǎn)移,那么可以采取在一個(gè)事務(wù)中執(zhí)行如下語(yǔ)句來(lái)實(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)”” 是用來(lái)補(bǔ)充原來(lái)不存在的數(shù)據(jù)的
4. 刪除臨時(shí)表
DROP TABLE __temp__Subscription;
通過(guò)以上四個(gè)步驟,就可以完成舊數(shù)據(jù)庫(kù)結(jié)構(gòu)向新數(shù)據(jù)庫(kù)結(jié)構(gòu)的遷移,并且其中還可以保證數(shù)據(jù)不會(huì)應(yīng)為升級(jí)而流失。
當(dāng)然,如果遇到減少字段的情況,也可以通過(guò)創(chuàng)建臨時(shí)表的方式來(lái)實(shí)現(xiàn)。
相關(guān)文章
Android自定義DataTimePicker日期時(shí)間選擇器使用詳解
這篇文章主要為大家詳細(xì)介紹了Android自定義DataTimePicker日期時(shí)間選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09
詳解Android中OkHttp3的例子和在子線(xiàn)程更新UI線(xiàn)程的方法
本篇文章主要介紹了詳解Android中OkHttp3的例子和在子線(xiàn)程更新UI線(xiàn)程的方法 ,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-05-05
Android開(kāi)發(fā)文件存儲(chǔ)實(shí)例
這篇文章主要為大家詳細(xì)介紹了Android開(kāi)發(fā)文件存儲(chǔ)實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
Android實(shí)現(xiàn)3D推拉門(mén)式滑動(dòng)菜單源碼解析
這篇文章主要為大家詳細(xì)解析了Android實(shí)現(xiàn)3D推拉門(mén)式滑動(dòng)菜單源碼以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。2017-11-11
Spinner在Dialog中的使用效果實(shí)例代碼詳解
這篇文章主要介紹了Spinner在Dialog中的使用效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
Android 下的 QuickJS Binding 庫(kù)特性使用詳解
這篇文章主要介紹了Android 下的 QuickJS Binding 庫(kù)特性使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
Android空心圓及層疊效果實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了Android空心圓及層疊效果實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
Android SurfaceView基礎(chǔ)用法詳解
這篇文章主要介紹了Android SurfaceView基礎(chǔ)用法詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
android使用ViewPager實(shí)現(xiàn)輪播效果
這篇文章主要為大家詳細(xì)介紹了android使用ViewPager實(shí)現(xiàn)輪播效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
android自定義控件實(shí)現(xiàn)簡(jiǎn)易時(shí)間軸(1)
這篇文章主要為大家詳細(xì)介紹了android自定義控件實(shí)現(xiàn)簡(jiǎn)易時(shí)間軸,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

