自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

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

[[271047]]

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

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

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

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

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

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

代碼如下:

  1. public class OrderDBHelper extends SQLiteOpenHelper { 
  2. private static final int DB_VERSION = 1; 
  3. private static final String DB_NAME = "Test.db"
  4. public static final String TABLE_NAME = "Orders"
  5. public OrderDBHelper(Context context, int version) { 
  6.  super(context, DB_NAME, null, version); 
  7. @Override 
  8. public void onCreate(SQLiteDatabase db) { 
  9.  String sql = "create table if not exists " + TABLE_NAME + " (Id integer primary key, " + 
  10.  "CustomName text, OrderPrice integer)"
  11.  db.execSQL(sql); 
  12. @Override 
  13. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
  14.  Log.e("owen""DB onUpgrade"); 
  15.  if (newVersion == 2) { 
  16.  db.execSQL("ALTER TABLE " + TABLE_NAME + " ADD COLUMN Country"); 
  17.  Cursor cr = db.rawQuery("select * from " + TABLE_NAME, null); 
  18.  while (cr.moveToNext()) { 
  19.  String name = cr.getString(cr.getColumnIndex("CustomName")); 
  20.  ContentValues values = new ContentValues(); 
  21.  values.put("CustomName"name); 
  22.  values.put("Country""China"); 
  23.  db.update(TABLE_NAME, values"CustomName=?", new String[] {name}); 
  24.  } 
  25.  cr.close(); 
  26.  } 
  27. OrderDBHelper orderDBHelper = new OrderDBHelper(this, 2); 
  28. SQLiteDatabase db = orderDBHelper.getWritableDatabase(); 
  29. ContentValues contentValues = new ContentValues(); 
  30. contentValues.put("OrderPrice", 100); 
  31. contentValues.put("CustomName""OwenChan"); 
  32. db.insert(OrderDBHelper.TABLE_NAME, null, contentValues); 
  33. Log.e("owen""create finish"); 
  34. Cursor cr = db.rawQuery("select * from " + OrderDBHelper.TABLE_NAME , null); 
  35. while (cr.moveToNext()) { 
  36.  String name = cr.getString(cr.getColumnIndex("CustomName")); 
  37.  Log.e("owen""name:" + name); 
  38.  String country = cr.getString(cr.getColumnIndex("Country")); 
  39.  Log.e("owen""country:" + country); 
  40. cr.close(); 
  41. db.close(); 

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

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

1、 將表名改成臨時(shí)表

ALTER TABLE Order RENAME TO _Order;

2、創(chuàng)建新表

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

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

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

4、刪除臨時(shí)表

DROPTABLE _Order;

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

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

  1. @Override 
  2. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
  3.  if (newVersion == 2) { 
  4.  char str = '"'
  5.  db.beginTransaction(); 
  6.  db.execSQL("ALTER TABLE Order RENAME TO _Order"); 
  7.  db.execSQL("CREATE TABLE Order(Id integer primary key autoincrement , CustomName VARCHAR(20) NOT NULL," 
  8.  + " Country VARCHAR(32) NOT NULL , OrderPrice VARCHAR(16) NOT NULL)"); 
  9.  db.execSQL("INSERT INTO Order SELECT Id, " + str + str 
  10.  + ", CustomName, OrderPrice FROM _Order"); 
  11.  db.setTransactionSuccessful(); 
  12.  db.endTransaction(); 
  13.  } 

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

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

  • V1.0 -> V3.0 DB 1 -> 2
  • V2.0 -> V3.0 DB 2 -> 3

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

  1. V1.0 —> TableA, TableB V1.2 —> TableA, TableB, TableC V1.3 —> TableA, TableB, TableC (Modify

代碼如下:

  1. @Override 
  2. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { 
  3.  if (1 == oldVersion) { 
  4.  String sql = "Create table C...."
  5.  db.execSQL(sql); 
  6.  oldVersion = 2; 
  7.  } 
  8.  if (2 == oldVersion) { 
  9.  //modify C 
  10.  oldVersion = 3; 
  11.  } 

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

  1. /** 
  2.  * Created by Owen Chan 
  3.  * On 2017-09-26. 
  4.  */ 
  5. public class DbManager { 
  6.  public static final String PACKAGE_NAME = "com.example.sql"
  7.  public static final String DB_NAME = "table.db"
  8.  public static final String DB_PATH = "/data/data/" + PACKAGE_NAME; 
  9.  private Context mContext; 
  10.  public DbManager(Context mContext) { 
  11.  this.mContext = mContext; 
  12.  } 
  13.  public SQLiteDatabase openDataBase() { 
  14.  return SQLiteDatabase.openOrCreateDatabase(DB_PATH + "/" + DB_NAME, null); 
  15.  } 
  16.  public void importDB() { 
  17.  File file = new File(DB_PATH + "/" + DB_NAME); 
  18.  if (!file.exists()) { 
  19.  try { 
  20.  FileOutputStream out = new FileOutputStream(file); 
  21.  int buffer = 1024; 
  22.  InputStream in = mContext.getResources().openRawResource(R.raw.xxxx); 
  23.  byte[] bts = new byte[buffer]; 
  24.  int lenght; 
  25.  while ((lenght = in.read(bts)) > 0) { 
  26.  out.write(bts, 0, bts.length); 
  27.  } 
  28.  out.close(); 
  29.  in.close(); 
  30.  } catch (Exception e) { 
  31.  e.printStackTrace(); 
  32.  } 
  33.  } 
  34.  } 

調(diào)用方式:

  1. @Override 
  2. protected void onResume() { 
  3.  super.onResume(); 
  4.  DbManager dbManager = new DbManager(this); 
  5.  dbManager.importDB(); 
  6.  SQLiteDatabase db = dbManager.openDataBase(); 
  7.  db.execSQL("do what you want"); 
責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2015-03-11 10:01:31

2016-08-25 08:57:21

RDBMS數(shù)據(jù)NoSQL

2021-01-28 09:00:00

SQL數(shù)據(jù)庫NoSQL

2024-01-29 10:49:58

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

2015-03-12 10:26:41

2009-03-19 09:50:25

遷移微軟Analysis Se

2011-04-06 17:30:41

SQL ServerSQL

2011-09-23 09:09:38

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

2020-08-13 07:42:15

數(shù)據(jù)庫Flyway代碼

2020-06-08 10:41:13

云計(jì)算數(shù)據(jù)工具

2022-08-08 09:20:41

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

2010-09-03 13:40:24

SQL刪除

2020-06-08 10:41:59

螞蟻集團(tuán)OceanBase

2011-03-30 08:56:43

Zabbix數(shù)據(jù)庫

2017-11-22 09:20:41

數(shù)據(jù)庫在線數(shù)據(jù)遷移Subscriptio

2009-03-19 09:44:07

SQL Server數(shù)據(jù)庫遷移數(shù)據(jù)庫

2011-05-11 10:26:36

MySQL數(shù)據(jù)庫無縫遷移

2019-08-13 15:52:34

數(shù)據(jù)庫同步遷移

2011-04-29 14:30:23

2024-04-10 07:16:17

JDBC驅(qū)動(dòng)MySQL數(shù)據(jù)庫
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)