久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

數(shù)據(jù)庫版本如何單獨升級并將原有數(shù)據(jù)遷移過去

140次閱讀
沒有評論

共計 5022 個字符,預(yù)計需要花費 13 分鐘才能閱讀完成。

本篇文章給大家分享的是有關(guān)數(shù)據(jù)庫版本如何單獨升級并將原有數(shù)據(jù)遷移過去,丸趣 TV 小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著丸趣 TV 小編一起來看看吧。

在我們開發(fā)的應(yīng)用中,一般都會涉及到數(shù)據(jù)庫,使用數(shù)據(jù)的時候會涉及到數(shù)據(jù)庫的升級、數(shù)據(jù)的遷移、增加行的字段等。比如,用戶定制數(shù)據(jù)的保存,文件的端點續(xù)傳信息的保存等都會涉及到數(shù)據(jù)庫。

我們應(yīng)用第一個版本是 V1.0,在迭代版本 V1.1   時,我們在數(shù)據(jù)庫中增加了一個字段。因此 V1.0 的數(shù)據(jù)庫在 V1.1 版本需要升級,V1.0 版本升級到 V1.1 時原來數(shù)據(jù)庫中的數(shù)據(jù)不能丟失,

那么在 V1.1 中就要有地方能夠檢測出來版本的差異,并且把 V1.0 軟件的數(shù)據(jù)庫升級到 V1.1 軟件能夠使用的數(shù)據(jù)庫。也就是說,要在 V1.0 軟件的數(shù)據(jù)庫的那個表中增加那個字段,并賦予這個字段默認值。  應(yīng)用中怎么檢測數(shù)據(jù)庫需要升級呢? SQLiteOpenHelper 類中有一個方法:

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}

當(dāng)我們創(chuàng)建對象的時候如果傳入的版本號大于之前的版本號,該方法就會被調(diào)用,通過判斷 oldVersion 和 newVersion   就可以決定如何升級數(shù)據(jù)庫。在這個函數(shù)中把老版本數(shù)據(jù)庫的相應(yīng)表中增加字段,并給每條記錄增加默認值即可。新版本號和老版本號都會作為 onUpgrade 函數(shù)的參數(shù)傳進來,便于開發(fā)者知道數(shù)據(jù)庫應(yīng)該從哪個版本升級到哪個版本。升級完成后,數(shù)據(jù)庫會自動存儲的版本號為當(dāng)前數(shù)據(jù)庫版本號。

數(shù)據(jù)庫升級

SQLite 提供了 ALTER  TABLE 命令,允許用戶重命名或添加新的字段到已有表中,但是不能從表中刪除字段。并且只能在表的末尾添加字段,比如, 為 Orders 表中添加一個字段:”ALTER  TABLE Order ADDCOLUMN Country”

代碼如下:

public class OrderDBHelper extends SQLiteOpenHelper { private static final int DB_VERSION = 1; private static final String DB_NAME =  Test.db  public static final String TABLE_NAME =  Orders  public OrderDBHelper(Context context, int version) { super(context, DB_NAME, null, version); } @Override public void onCreate(SQLiteDatabase db) { String sql =  create table if not exists   + TABLE_NAME +   (Id integer primary key,   +  CustomName text, OrderPrice integer)  db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { Log.e( owen ,  DB onUpgrade  if (newVersion == 2) { db.execSQL( ALTER TABLE   + TABLE_NAME +   ADD COLUMN Country  Cursor cr = db.rawQuery( select * from   + TABLE_NAME, null); while (cr.moveToNext()) { String name = cr.getString(cr.getColumnIndex( CustomName)); ContentValues values = new ContentValues(); values.put( CustomName , name); values.put(Country ,  China  db.update(TABLE_NAME, values,  CustomName=? , new String[] {name}); } cr.close(); } } OrderDBHelper orderDBHelper = new OrderDBHelper(this, 2); SQLiteDatabase db = orderDBHelper.getWritableDatabase(); ContentValues contentValues = new ContentValues(); contentValues.put(OrderPrice , 100); contentValues.put(CustomName ,  OwenChan  db.insert(OrderDBHelper.TABLE_NAME, null, contentValues); Log.e(owen ,  create finish  Cursor cr = db.rawQuery( select * from   + OrderDBHelper.TABLE_NAME , null); while (cr.moveToNext()) { String name = cr.getString(cr.getColumnIndex( CustomName)); Log.e(owen ,  name:  + name); String country = cr.getString(cr.getColumnIndex( Country)); Log.e(owen ,  country:  + country); } cr.close(); db.close();

數(shù)據(jù)庫的遷移

可以分一下幾個步驟遷移數(shù)據(jù)庫。

1、將表名改成臨時表

ALTER TABLE Order RENAME TO _Order;

2、創(chuàng)建新表

CREATETABLE Test(Id VARCHAR(32) PRIMARY KEY ,CustomName VARCHAR(32) NOTNULL , Country VARCHAR(16) NOTNULL);

3、導(dǎo)入數(shù)據(jù)

INSERTINTO Order SELECT id, “”, Age FROM _Order;

4、刪除臨時表

DROPTABLE _Order;

通過以上四個步驟,就可以完成舊數(shù)據(jù)庫結(jié)構(gòu)向新數(shù)據(jù)庫結(jié)構(gòu)的遷移,并且其中還可以保證數(shù)據(jù)不會因為升級而流失。  當(dāng)然,如果遇到減少字段的情況,也可以通過創(chuàng)建臨時表的方式來實現(xiàn)。

實現(xiàn)代碼如下:

@Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { if (newVersion == 2) { char str =   db.beginTransaction(); db.execSQL(ALTER TABLE Order RENAME TO _Order  db.execSQL( CREATE TABLE Order(Id integer primary key autoincrement , CustomName VARCHAR(20) NOT NULL,  +   Country VARCHAR(32) NOT NULL , OrderPrice VARCHAR(16) NOT NULL)  db.execSQL(INSERT INTO Order SELECT Id,   + str + str +  , CustomName, OrderPrice FROM _Order  db.setTransactionSuccessful(); db.endTransaction(); } }

多個數(shù)據(jù)庫版本的升級

假如我們開發(fā)的程序已經(jīng)發(fā)布了兩個版本:V1.0,V2.0,我們正在開發(fā) V3.0。版本號分別是 1,2,3。對于這種情況,我們應(yīng)該如何實現(xiàn)升級?   用戶的選擇有:

V1.0 – V3.0 DB 1 – 2

V2.0 – V3.0 DB 2 – 3

數(shù)據(jù)庫的每一個版本所代表的數(shù)據(jù)庫必須是定義好的,比如說 V1.0 的數(shù)據(jù)庫,它可能只有兩張表 TableA 和 TableB,如果 V2.0 要添加一張表 TableC,如果 V3.0 要修改 TableC,數(shù)據(jù)庫結(jié)構(gòu)如下:

V1.0  mdash;  TableA, TableB V1.2  mdash;  TableA, TableB, TableC V1.3  mdash;  TableA, TableB, TableC (Modify)

代碼如下:

@Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { if (1 == oldVersion) { String sql =  Create table C....  db.execSQL(sql); oldVersion = 2; } if (2 == oldVersion) { //modify C oldVersion = 3; } }

導(dǎo)入已有數(shù)據(jù)庫:

/** * Created by Owen Chan * On 2017-09-26. */ public class DbManager { public static final String PACKAGE_NAME =  com.example.sql  public static final String DB_NAME =  table.db  public static final String DB_PATH =  /data/data/  + PACKAGE_NAME; private Context mContext; public DbManager(Context mContext) { this.mContext = mContext; } public SQLiteDatabase openDataBase() { return SQLiteDatabase.openOrCreateDatabase(DB_PATH +  /  + DB_NAME, null); } public void importDB() { File file = new File(DB_PATH +  /  + DB_NAME); if (!file.exists()) { try { FileOutputStream out = new FileOutputStream(file); int buffer = 1024; InputStream in = mContext.getResources().openRawResource(R.raw.xxxx); byte[] bts = new byte[buffer]; int lenght; while ((lenght = in.read(bts))   0) { out.write(bts, 0, bts.length); } out.close(); in.close(); } catch (Exception e) { e.printStackTrace(); } } } }

調(diào)用方式:

@Override protected void onResume() { super.onResume(); DbManager dbManager = new DbManager(this); dbManager.importDB(); SQLiteDatabase db = dbManager.openDataBase(); db.execSQL(do what you want  }

以上就是數(shù)據(jù)庫版本如何單獨升級并將原有數(shù)據(jù)遷移過去,丸趣 TV 小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注丸趣 TV 行業(yè)資訊頻道。

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-07-17發(fā)表,共計5022字。
轉(zhuǎn)載說明:除特殊說明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 日照市| 永靖县| 扬州市| 嘉祥县| 磴口县| 海淀区| 江陵县| 大关县| 龙州县| 泉州市| 滦南县| 甘孜| 黑河市| 乡宁县| 武义县| 广昌县| 鸡泽县| 吴桥县| 井陉县| 昔阳县| 鸡泽县| 宜城市| 贡山| 循化| 高尔夫| 抚州市| 金坛市| 康定县| 双流县| 新河县| 偏关县| 泗水县| 汉川市| 塔河县| 吉木乃县| 佛坪县| 贵定县| 仁怀市| 新丰县| 武乡县| 玉环县|