Android數(shù)據(jù)庫升級(jí)暇仲,數(shù)據(jù)遷移。同時(shí)也適用GreenDao

版本迭代時(shí)難免需要對(duì)數(shù)據(jù)庫字段進(jìn)行增加副渴,刪除與修改操作奈附。這時(shí)便需要對(duì)原有的數(shù)據(jù)進(jìn)行遷移,以保證不丟失數(shù)據(jù)煮剧。對(duì)數(shù)據(jù)庫的遷移我們需要做以下幾個(gè)步驟:

  • ① 創(chuàng)建臨時(shí)表斥滤,將原來的數(shù)據(jù)復(fù)制到臨時(shí)表中。
  • ② 刪除原表勉盅,原表數(shù)據(jù)已經(jīng)備份至臨時(shí)表中佑颇,不再需要,進(jìn)行刪除草娜。
  • ③ 創(chuàng)建新表挑胸,調(diào)用創(chuàng)建新表的方法,創(chuàng)建所有的新表宰闰。
  • ④ 恢復(fù)原表的數(shù)據(jù)茬贵,將臨時(shí)表中的數(shù)據(jù)恢復(fù)至新表中。
  • ⑤ 刪除臨時(shí)表议蟆,完成所有的步驟闷沥。

Show Code:

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.text.TextUtils;

import java.util.ArrayList;
import java.util.List;

/**
 * Created by CY on 2016/10/24.
 * Email: tmxdyf@163.com
 */

public class UpgradeHelper {


    /**
     * 升級(jí)入口
     *
     * @param db db
     * @param openHelper 重新建表時(shí)需要用上
     */
    public void upgrade(SQLiteDatabase db, SQLiteOpenHelper openHelper) {
        List<String> tables = queryAllTables(db);

        for (String tableName : tables) {
            if ("android_metadata".equals(tableName)||"sqlite_sequence".equals(tableName)) {//表的元數(shù)據(jù),過濾
                continue;
            }
            String tempTableName = tableName + "_Temp";
            createTempTables(db, tableName, tempTableName);//創(chuàng)建臨時(shí)表
            dropTable(db, tableName);//刪除原表
            openHelper.onCreate(db);//創(chuàng)建新表
            restoreData(db, tableName, tempTableName);//恢復(fù)原表數(shù)據(jù)
            dropTable(db, tempTableName);//刪除臨時(shí)表
        }
    }


    /**
     * 創(chuàng)建零時(shí)表
     */
    private void createTempTables(SQLiteDatabase db, String tableName, String tempTableName) {
        copyTable(db, tableName, tempTableName);
    }


    /**
     * 刪除所有表
     *
     * @param db
     */
    private void dropTable(SQLiteDatabase db, String tableName) {

        String sql = "DROP TABLE IF EXISTS " + tableName;

        db.execSQL(sql);

    }


    /**
     * 查詢數(shù)據(jù)庫中所有表名
     *
     * @param db
     * @return
     */
    private List<String> queryAllTables(SQLiteDatabase db) {
        List<String> list = new ArrayList<>();
        String sql = "SELECT name FROM SQLITE_MASTER WHERE type='table' ORDER BY name";
        Cursor cursor = db.rawQuery(sql, null);
        while (cursor.moveToNext()) {
            list.add(cursor.getString(0));
        }
        cursor.close();
        return list;
    }


    /**
     * 復(fù)制表及內(nèi)容
     *
     * @param db
     * @param oldTableName
     * @param newTableName
     */
    private void copyTable(SQLiteDatabase db, String oldTableName, String newTableName) {

        String sql = "CREATE TABLE IF NOT EXISTS " + newTableName + " AS SELECT * FROM " + oldTableName;
        db.execSQL(sql);
    }


    /**
     * 從臨時(shí)表中恢復(fù)數(shù)據(jù)
     *
     * @param db
     * @param tableName     需要恢復(fù)的表
     * @param tableNameTemp 臨時(shí)表
     */
    private void restoreData(SQLiteDatabase db, String tableName, String tableNameTemp) {


        String columns = TextUtils.join(",", queryColumns(db, tableNameTemp));

        String sql = "INSERT INTO " + tableName + "(" + columns + ") SELECT " + columns + " FROM " + tableNameTemp;

        db.execSQL(sql);

    }

    /**
     * 獲取表中所有字段名
     *
     * @return
     */
    private String[] queryColumns(SQLiteDatabase db, String tableName) {

        String sql = "SELECT * FROM " + tableName;
        Cursor cursor = db.rawQuery(sql, null);
        String[] columnNames = cursor.getColumnNames();
        cursor.close();

        return columnNames;
    }
}

如何使用咐容?如以下示例舆逃。

  • E.g: GreenDao
  public class MergeDevOpenHelper extends DaoMaster.DevOpenHelper {

        public MergeDevOpenHelper(Context context, String name) {
            super(context, name);
        }

        public MergeDevOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory) {
            super(context, name, factory);
        }

        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            if (newVersion > oldVersion) {
                new UpgradeHelper().upgrade(db, this);
            }
        }

    }


}
 DaoMaster.DevOpenHelper devOpenHelper = new MergeDevOpenHelper(mContext, "data.db");
 SQLiteDatabase db = devOpenHelper.getWritableDatabase();
 DaoMaster daoMaster = new DaoMaster(db);

這是我在簡書的第一篇文章,希望能幫助到大家戳粒,同時(shí)也給我自己加深記憶路狮。謝謝。_

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蔚约,一起剝皮案震驚了整個(gè)濱河市奄妨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌苹祟,老刑警劉巖砸抛,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異树枫,居然都是意外死亡直焙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門砂轻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來奔誓,“玉大人,你說我怎么就攤上這事搔涝〕梗” “怎么了和措?”我有些...
    開封第一講書人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蜕煌。 經(jīng)常有香客問我派阱,道長,這世上最難降的妖魔是什么斜纪? 我笑而不...
    開封第一講書人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任颁褂,我火速辦了婚禮,結(jié)果婚禮上傀广,老公的妹妹穿的比我還像新娘。我一直安慰自己彩届,他們只是感情好伪冰,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著樟蠕,像睡著了一般贮聂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上寨辩,一...
    開封第一講書人閱讀 49,760評(píng)論 1 289
  • 那天吓懈,我揣著相機(jī)與錄音,去河邊找鬼靡狞。 笑死耻警,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的甸怕。 我是一名探鬼主播甘穿,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼梢杭!你這毒婦竟也來了温兼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤武契,失蹤者是張志新(化名)和其女友劉穎募判,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體咒唆,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡届垫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了钧排。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片敦腔。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖恨溜,靈堂內(nèi)的尸體忽然破棺而出符衔,到底是詐尸還是另有隱情找前,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布判族,位于F島的核電站躺盛,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏形帮。R本人自食惡果不足惜槽惫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望辩撑。 院中可真熱鬧界斜,春花似錦、人聲如沸合冀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽君躺。三九已至峭判,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間棕叫,已是汗流浹背林螃。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留俺泣,地道東北人疗认。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像伏钠,于是被迫代替她去往敵國和親侮邀。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容