Android資料庫版本升級

來源:互聯網
上載者:User

標籤:csdn部落格   ondowngrade   sqlite升級   

android應用在發布後,會進行版本迭代。其中因為需求的更改,功能的擴充,可能會涉及到資料庫的升級。如果只是添加表,還比較好處理,直接在public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)中建立表就OK了,但是涉及到已存在的表的結構發生變更,就比較麻煩了,特別是之前已經升級過表的結構,再次升級的時候需要考慮使用者當前的版本,也就是需要在代碼裡對不同版本的資料庫,升級到最新版本進行處理。其實這個跟製作增量升級包差不多,需要為每個曆史版本製作一個增量包。

雖然CSDNBlog目前還沒有涉及到資料庫升級,但是提前準備好還是有必要的。接下來就把這兩天學習到的sqlite資料庫升級總結一下:

當資料庫不存在的時候,會調用SQLiteOpenHelper的onCreate()方法;之後啟動應用,若資料庫已經存在,就不會再次調用該方法了。當資料庫版本號碼發生變動時會調用相應的方法。

<span style="white-space:pre"></span>// 構造方法private DB(Context context) {// 建立資料庫super(context, DB_NAME, null, DATABASE_VERSION);Log.i(TAG, "create database");}

上面的代碼是建立SQLiteOpenHelper的執行個體(DB類繼承的SQLiteOpenHelper),其中DATABASE_VERSION就是自訂的資料庫版本號碼。

如果應用啟動時發現DATABASE_VERSION小於當前資料庫的版本號碼時,也是就是需要對資料庫進行降級操作,會調用下面的方法:

@Overridepublic void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {super.onDowngrade(db, oldVersion, newVersion);}

當然,基本上不會使用降級,我在實驗的時候,忘記當前的資料庫版本號碼,也沒有覆寫onDowngrade方法,隨便給個版本號碼,運行之後會出現無響應,或者其他一些奇怪的現象。

進行資料庫升級的時候,會調用onUpgrade方法,在此方法裡面,我們不僅要更新表結構,還要考慮到表中的資料保留問題。當然直接刪除舊錶,重建立表格會很爽,但是使用者積累的資料就沒有了。也就是說,我們需要把舊錶的資料儲存到新表。

思路是:先更改舊錶的表名(如果升級後表名發生變化的話,就不需要這一步了),建立表,然後就根據舊錶的結構把資料重新插入新表。

// 版本更新時調用@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {//需要轉移資料的欄位String columns = "";Log.i(TAG, "oldVersion=" + oldVersion);//根據不同的資料庫版本進行資料的備份switch (oldVersion) {case 1:columns = BlogInfo.TITLE + "," + BlogInfo.LINK + ","+ BlogInfo.DESCRIPTION + "," + BlogInfo.MSG + ","+ BlogInfo.DATESTAMP + "," + BlogInfo.TIMESTAMP_READ + ","+ BlogInfo.CONTENT + "," + BlogInfo.TYPE_BLOG + ","+ BlogInfo.TYPE_ARTICLE;break;case 2:break;default:db.execSQL("DROP TABLE IF EXISTS " + TB_BLOG);db.execSQL("DROP TABLE IF EXISTS " + TB_BLOGER);onCreate(db);// 建立新表return;}//開始準備資料try {db.beginTransaction();Log.i(TAG, "Rename table.");String tempTableName = TB_BLOG + "_temp";String sql = "ALTER TABLE " + TB_BLOG + " RENAME TO " + tempTableName;db.execSQL(sql);Log.i(TAG, "Create table.");onCreate(db);// 建立新表Log.i(TAG, "Load data");sql = "INSERT INTO " + TB_BLOG + " (" + columns + ") " + " SELECT " + columns + " FROM " + tempTableName;db.execSQL(sql);Log.i(TAG, "Drop the temporary table.");db.execSQL("DROP TABLE IF EXISTS " + tempTableName);db.setTransactionSuccessful();db.endTransaction();} catch (Exception e) { } }

如果資料庫有多個曆史版本,就需要在switch中一一處理,當然,如果沒有考慮到的情況,只能慘然的刪除重建了。

其中有一句是直接調用回呼函數onCreate(db)

onCreate(db);// 建立新表
雖然感覺很奇怪,但確實可行。


因為暫時還沒有用到資料庫的升級,所以現在只是簡單的把功能實現,以後根據需求再完善。

如有大神指點,感激不盡!

Android資料庫版本升級

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.