在Android中afinal框架下實現sqlite數據庫版本升級的辦法

public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version) 這個方法在實現時需要重寫。

 
1
public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version)

 

這個方法在實現時需要重寫。

onUpgrade方法會在數據庫需要升級的時候調用。可以用來增刪表或者其他任何操作。如果你想添加新的列你可以使用ALTER TABLE 插入表中。如果需要重命名或者刪掉列,可以使用ALTER TABLE 重命名舊表,然後創建新的表,並將舊表數據添加到新表中。如果拋出異常,將自動回滾。

 

1. 幫助文檔裏說的“數據庫升級”是指什麼?

你開發了一個程序,當前是1.0版本。該程序用到了數據庫。到1.1版本時,你在數據庫的某個表中增加了一個字段。那麼軟件1.0版本用的數據庫在軟件1.1版本就要被升級了。

2. 數據庫升級應該注意什麼?

軟件的1.0版本升級到1.1版本時,老的數據不能丟。那麼在1.1版本的程序中就要有地方能夠檢測出來新的軟件版本與老的數據庫不兼容,並且能夠有辦法把1.0軟件的數據庫升級到1.1軟件能夠使用的數據庫。換句話說,要在1.0軟件的數據庫的那個表中增加那個字段,並賦予這個字段默認值。

3. 程序如何知道數據庫需要升級?

SQLiteOpenHelper類的構造函數有一個参數是int version,它的意思就是指數據庫版本號。比如在軟件1.0版本中,我們使用SQLiteOpenHelper訪問數據庫時,該参數为1,那麼數據庫版本號1就會寫在我們的數據庫中。

到了1.1版本,我們的數據庫需要發生變化,那麼我們1.1版本的程序中就要使用一個大於1的整數來構造SQLiteOpenHelper類,用於訪問新的數據庫,比如2。

當我們的1.1新程序讀取1.0版本的老數據庫時,就發現老數據庫裏存儲的數據庫版本是1,而我們新程序訪問它時填的版本號为2,系統就知道數據庫需要升級。

4. 何時觸發數據庫升級?如何升級?

當系統在構造SQLiteOpenHelper類的對象時,如果發現版本號不一样,就會自動調用onUpgrade函數,讓你在這裏對數據庫進行升級。根據上述場景,在這個函數中把老版本數據庫的相應表中增加字段,並给每條記錄增加默認值即可。

新版本號和老版本號都會作为onUpgrade函數的参數傳進來,便於開發者知道數據庫應該從哪個版本升級到哪個版本。

升級完成後,數據庫會自動存儲最新的版本號为當前數據庫版本號。

-----------------------------------------------------------------------------------------------------------------

上面采用的是SQLiteOpenHelper中的onUpgrade方法實現數據庫的升級。

     首先獲取Context:

1
private Context  mContext=this;

 

然後實現FinalDb內的靜態方法:

 

1
FinalDb.create(mContext,"afinal.db",true,2,this);

 

實現FinalDb的DbUpdateListener接口中的方法:

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@Override
    public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) {
 
        // TODO Auto-generated method stub
        try {
            InputStream in = mContext.getAssets().open("patch.sql");
            BufferedReader bufferedReader = new BufferedReader(
                    new InputStreamReader(in));
            String sqlUpdate = null;
            while ((sqlUpdate = bufferedReader.readLine()) != null) {
                if (!TextUtils.isEmpty(sqlUpdate)) {
                    db.execSQL(sqlUpdate);
                }
            }
            bufferedReader.close();
            in.close();
        } catch (SQLException e) {
            System.out.println(e.toString());
        } catch (IOException e) {
            System.out.println(e.toString());
        }  
    }

 

時間緊迫,沒有寫太多,大家可以自己研究。

posted @   Bigben  阅读(219)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示