加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

数据库版本如何单独升级,并且将原有数据迁移过去

发布时间:2019-07-18 16:33:01 所属栏目:MySql教程 来源:Android架构师
导读:副标题#e# 在我们开发的应用中,一般都会涉及到数据库,使用数据的时候会涉及到数据库的升级、数据的迁移、增加行的字段等。比如,用户定制数据的保存,文件的端点续传信息的保存等都会涉及到数据库。 我们应用第一个版本是V1.0,在迭代版本V1.1 时,我们在

2、创建新表

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

3、导入数据

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

4、删除临时表

DROPTABLE _Order;

通过以上四个步骤,就可以完成旧数据库结构向新数据库结构的迁移,并且其中还可以保证数据不会因为升级而流失。 当然,如果遇到减少字段的情况,也可以通过创建临时表的方式来实现。

实现代码如下

  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.  } 

多个数据库版本的升级

假如我们开发的程序已经发布了两个版本:V1.0,V2.0,我们正在开发V3.0。版本号分别是1,2,3。对于这种情况,我们应该如何实现升级? 用户的选择有:

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

数据库的每一个版本所代表的数据库必须是定义好的,比如说V1.0的数据库,它可能只有两张表TableA和TableB,如果V2.0要添加一张表TableC,如果V3.0要修改TableC,数据库结构如下:

  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.  } 

导入已有数据库

  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.  } 

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读