精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

數據庫版本如何單獨升級,并且將原有數據遷移過去

數據庫 其他數據庫
在我們開發的應用中,一般都會涉及到數據庫,使用數據的時候會涉及到數據庫的升級、數據的遷移、增加行的字段等。比如,用戶定制數據的保存,文件的端點續傳信息的保存等都會涉及到數據庫。

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

[[271047]]

​我們應用***個版本是V1.0,在迭代版本V1.1 時,我們在數據庫中增加了一個字段。因此V1.0的數據庫在V1.1版本需要升級,V1.0版本升級到V1.1時原來數據庫中的數據不能丟失,

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

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

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

數據庫升級

SQLite提供了ALTER TABLE命令,允許用戶重命名或添加新的字段到已有表中,但是不能從表中刪除字段。并且只能在表的末尾添加字段,比如,為Orders 表中添加一個字段:”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(); 

數據庫的遷移

可以分一下幾個步驟遷移數據庫。

1、 將表名改成臨時表

ALTER TABLE Order RENAME TO _Order;

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

調用方式:

  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"); 
責任編輯:武曉燕 來源: 今日頭條
相關推薦

2015-03-11 10:01:31

2016-08-25 08:57:21

RDBMS數據NoSQL

2021-01-28 09:00:00

SQL數據庫NoSQL

2024-01-29 10:49:58

數據庫遷移

2015-03-12 10:26:41

2009-03-19 09:50:25

遷移微軟Analysis Se

2011-04-06 17:30:41

SQL ServerSQL

2020-08-13 07:42:15

數據庫Flyway代碼

2011-09-23 09:09:38

數據庫遷移

2022-08-08 09:20:41

數據庫遷移

2010-09-03 13:40:24

SQL刪除

2020-06-08 10:41:13

云計算數據工具

2020-06-08 10:41:59

螞蟻集團OceanBase

2025-08-13 08:49:55

2011-03-30 08:56:43

Zabbix數據庫

2017-11-22 09:20:41

數據庫在線數據遷移Subscriptio

2024-04-10 07:16:17

JDBC驅動MySQL數據庫

2011-04-29 14:30:23

2011-05-11 10:26:36

MySQL數據庫無縫遷移

2009-03-19 09:44:07

SQL Server數據庫遷移數據庫
點贊
收藏

51CTO技術棧公眾號

国产一级免费视频| 中国黄色片一级| 日本黄色不卡视频| 亚洲综合电影一区二区三区| 日韩电影在线观看中文字幕| 日本网站免费在线观看| 日韩精品视频在线观看一区二区三区| 9色国产精品| 亚洲全黄一级网站| 999这里有精品| 蜜桃传媒在线观看免费进入| 99久久夜色精品国产网站| 欧美性一区二区三区| 国产1区2区在线观看| 在线不卡一区| 亚欧色一区w666天堂| 日本高清不卡三区| 国产乱色精品成人免费视频| 亚洲先锋成人| 亚洲欧洲午夜一线一品| 天天干天天色天天干| 青草在线视频| 欧美韩国一区二区| 7777精品久久久大香线蕉小说| 日产精品久久久久久久| 欧美久久综合网| 欧美视频三区在线播放| 一二三四中文字幕| 色综合成人av| 国产综合一区二区| 91精品国产成人| 成人免费视频入口| 精品三级av| 欧美日韩不卡在线| 国产黄页在线观看| 国产精品一区二区三区视频网站| 北岛玲一区二区三区四区| 成人黄色av播放免费| 99成人精品视频| 免费日韩精品中文字幕视频在线| 欧美精品激情在线观看| 国产免费久久久久| 久久国产影院| 日韩中文在线视频| 九一在线免费观看| 人人狠狠综合久久亚洲婷| 日韩激情在线视频| 四虎国产精品免费| 欧美高清影院| 91极品美女在线| 少妇av一区二区三区无码| 国产黄色在线免费观看| 国产精品美女久久久久高潮| 久久婷婷人人澡人人喊人人爽| 国产人妖一区二区三区| 日韩综合一区二区| 全球成人中文在线| www.天天色| 在线精品一区二区| 欧美第一淫aaasss性| 裸体武打性艳史| 欧美第一精品| 精品粉嫩aⅴ一区二区三区四区| 青青草原国产在线视频| 伊人久久高清| 欧美中文字幕亚洲一区二区va在线| 免费看黄在线看| 精灵使的剑舞无删减版在线观看| 亚洲欧美怡红院| 五月天久久综合网| 国产三级视频在线看| 久久亚洲春色中文字幕久久久| 国产亚洲一区二区三区在线播放 | 久久久久久网址| 不卡的免费av| 久久精品观看| 国产男人精品视频| 伊人免费在线观看| 蜜臀av性久久久久av蜜臀妖精| 国产精品国产亚洲伊人久久| 精人妻无码一区二区三区| 久久天堂成人| 国产精品欧美激情| 一二区在线观看| 国产自产视频一区二区三区| av成人观看| 成人欧美一区二区三区在线 | 国产一区二区三区免费观看在线| 欧美日韩一本到| 亚洲一区在线不卡| 丰满少妇一区| 91精品久久久久久久91蜜桃| 91网址在线观看精品| 国产麻豆一区二区三区| 欧美精品在线一区二区三区| 色男人天堂av| 精品欠久久久中文字幕加勒比| 日韩电影大片中文字幕| 91网站免费视频| 日韩精品欧美| 久久国产精品偷| 国产在线视频你懂的| 日韩天堂av| 国产精品久久久久久超碰| 一级特黄特色的免费大片视频| 国产专区欧美精品| 国产精品一区二区三区不卡| 男人的天堂在线| 国产精品久久久久久亚洲毛片| 成人性做爰片免费视频| 国产精品一区hongkong| 色综合中文综合网| 日本中文字幕二区| 波多野结衣一区二区三区免费视频| 精品播放一区二区| 美女洗澡无遮挡| 欧美人成网站| 日本精品久久久久久久| 中文字幕免费高清在线观看| 国产美女av一区二区三区| 好吊妞www.84com只有这里才有精品| 欧美午夜黄色| 亚洲人成电影网站色mp4| 奇米精品一区二区三区| 四虎国产精品成人免费影视| 亚洲二区中文字幕| 蜜桃av免费在线观看| 伊人久久久大香线蕉综合直播| 日本精品一区二区三区在线| 一级黄色片免费| 精品少妇在线视频| www.日日夜夜| 欧美国产精品一区二区三区| 在线观看18视频网站| 国模套图日韩精品一区二区| 91 com成人网| 国产免费一区二区三区网站免费| 午夜精品久久99蜜桃的功能介绍| 日本免费久久高清视频| 国产 日韩 欧美 综合| 国产欧美精品日韩区二区麻豆天美| 看一级黄色录像| 福利一区二区| 亚洲免费视频一区二区| 久久综合色综合| 麻豆视频观看网址久久| 欧美凹凸一区二区三区视频| 在线三级中文| 欧美美女网站色| 国产成人精品无码免费看夜聊软件| 欧美日韩午夜| 国产精品成人av性教育| 香蕉视频网站在线| 亚洲一区二区三区三| 国产免费中文字幕| 色男人天堂综合再现| 日本视频久久久| 天天干天天做天天操| 亚洲伊人色欲综合网| 午夜精品久久久久久久99热影院| 免费成人高清在线视频theav| 欧美激情精品久久久久久黑人| 亚洲手机在线观看| 国产农村妇女毛片精品久久麻豆| 六月丁香激情网| 久久99偷拍| 国内自拍欧美激情| 日本黄色一区二区三区| 亚洲在线视频一区| 一区二区三区四区影院| 国产专区一区| 国产精品sss| av电影院在线看| 欧美精品一区二区不卡| 免费在线观看国产精品| 国产激情偷乱视频一区二区三区| 超碰97免费观看| 91精品视频一区二区| 日韩在线观看免费高清| 一区二区三区黄| 亚洲欧美一区二区三区极速播放 | 日韩欧美在线观看| 在线 丝袜 欧美 日韩 制服| 亚洲女人av| 欧美日韩综合精品| 成人精品国产亚洲| 日韩中文理论片| 中文字幕 视频一区| 中文字幕日韩精品一区| 午夜影院免费版| 亚洲网站在线| 久久久精品国产一区二区三区| 国产精品剧情一区二区在线观看| 欧美一区二区大片| 日韩大片免费在线观看| 久久久蜜桃精品| 小泽玛利亚视频在线观看| 亚洲第一偷拍| 国产精品入口免费| 欧美男体视频| 中文字幕精品在线视频| 精品国产九九九| 午夜电影网一区| 丰满少妇一区二区三区| 日本三级亚洲精品| 国产资源第一页| 日韩美脚连裤袜丝袜在线| 国产精品第1页| 亚洲区欧洲区| 国产亚洲精品美女久久久| 国产乱人乱偷精品视频a人人澡| 亚洲成人免费观看| jizz18女人高潮| 国产精品18久久久久久vr| 欧美牲交a欧美牲交aⅴ免费下载| 欧美大黑bbbbbbbbb在线| 国产精品免费一区二区三区| 欧美影视资讯| 97高清免费视频| www在线观看播放免费视频日本| 亚洲人成电影网| 六月婷婷综合网| 欧美精品 国产精品| 国产成人自拍偷拍| 韩曰欧美视频免费观看| 日本免费网站视频| 久久久久久久综合日本| 亚洲色图欧美另类| 精品无人区卡一卡二卡三乱码免费卡| 一卡二卡三卡视频| 精品日本12videosex| 99亚洲伊人久久精品影院红桃| 成人国产精品色哟哟| 色黄视频在线观看| 九九热99久久久国产盗摄| 男生女生差差差的视频在线观看| 日韩欧美激情四射| 一区二区三区免费观看视频| 欧美性猛交xxxx乱大交蜜桃| 欧美日韩成人免费观看| 国产精品久久久久久久久晋中 | 大香伊人久久| 日韩一二三在线视频播| 亚洲日本在线播放| 精品久久久久香蕉网| 国产免费的av| 欧美日韩成人综合在线一区二区| 亚洲欧美一二三区| 欧美午夜激情小视频| 国产网址在线观看| 亚洲一区在线免费观看| 日本福利片在线观看| 中文字幕中文字幕一区二区 | 69精品国产久热在线观看| 国产日韩欧美在线播放| 欧美精选视频一区二区| 清纯唯美亚洲激情| 中文字幕在线直播| 97国产一区二区精品久久呦| 爆操欧美美女| 久久久999国产| 国产在线视频你懂得| 精品视频一区在线视频| 亚洲av成人无码久久精品老人| 精品国产伦一区二区三区免费| 国产福利资源在线| 日韩欧美专区在线| 精品人妻一区二区三区日产乱码| 337p亚洲精品色噜噜噜| 国产精品一级视频| 91精品国产综合久久婷婷香蕉| 在线观看亚洲黄色| 欧美日韩另类一区| 国产又黄又粗又猛又爽| 欧美一二三在线| 亚洲av无码一区二区乱子伦| 日韩精品一区二区三区蜜臀| 欧美熟妇乱码在线一区| 亚洲精品国产精品国自产在线| 天天在线女人的天堂视频| 日韩精品在线免费观看视频| 成人免费观看在线视频| 精品粉嫩超白一线天av| 日漫免费在线观看网站| 亚洲性无码av在线| 日本网站在线免费观看视频| 久久精品一本久久99精品| 亚洲区欧洲区| 7m第一福利500精品视频| 在线观看欧美日韩电影| 欧美又大又粗又长| 成人性生交大片免费观看网站| 国产va免费精品高清在线观看 | 亚洲精品免费播放| 国产一级特黄aaa大片| 岛国av一区二区在线在线观看| 国产免费a视频| 67194成人在线观看| 高h放荡受浪受bl| 亚洲新中文字幕| 免费网站成人| 久久久久久久久久婷婷| 亚洲欧美电影| 成人免费xxxxx在线观看| 国产精品xxx在线观看| 日韩国产欧美一区| 亚洲精品一二三区区别| 欧美精品自拍视频| 国产一区白浆| 五月婷婷之婷婷| thepron国产精品| 日本美女xxx| 亚洲国产成人av| 中文 欧美 日韩| 亚洲国产高清福利视频| 成人三级黄色免费网站| 久久久亚洲精选| 美女视频一区| 久99久视频| 欧美一区二区三区高清视频| 久久久天堂国产精品| 视频在线观看一区| 亚洲成人福利视频| 亚洲国产经典视频| 久久久精品91| 欧美日韩一区成人| 五月婷婷丁香花| 日韩在线视频观看| mm视频在线视频| 成人a视频在线观看| 日本午夜精品| 国产在线无码精品| 日韩高清欧美激情| v天堂中文在线| 亚洲激情在线播放| 艳妇乳肉豪妇荡乳av无码福利| 亚洲成人av在线| 在线观看三级视频| 国产精品视频免费观看www| 国产主播性色av福利精品一区| 一本久道久久综合狠狠爱亚洲精品| 亚洲欧美激情诱惑| 亚洲美女精品视频| 久久久.com| 日本少妇久久久| 日韩亚洲欧美综合| 蜜桃视频网站在线观看| 国产精品久久av| 伊人成综合网伊人222| 青青草国产免费| 国产麻豆精品视频| 精品无人区无码乱码毛片国产 | 中文字幕va一区二区三区| 国产又大又黄又粗| 日韩精品小视频| 日本综合字幕| 手机在线观看国产精品| 美女一区二区视频| 极品美妇后花庭翘臀娇吟小说| 欧美日韩高清影院| av网址在线免费观看| 91久久夜色精品国产网站| 午夜电影亚洲| 国产污在线观看| 欧美日韩免费在线| 国产区在线视频| 国产中文字幕91| 欧美女人交a| 91玉足脚交白嫩脚丫| 色一情一乱一乱一91av| 在线视频91p| 亚洲最大成人免费视频| 亚洲国产精品一区| 色哟哟精品观看| 91超碰这里只有精品国产| 在线电影福利片| 久久综合久久久| 精品一区二区在线观看| 18精品爽视频在线观看| 亚洲欧美www| 亚洲精品成a人ⅴ香蕉片| 欧美国产综合在线| 久久久久国产免费免费| 亚洲天堂视频在线| 久久97精品久久久久久久不卡| 免费看久久久| 加勒比av中文字幕| 五月婷婷欧美视频| 自拍视频在线| 国产专区一区二区三区| 蜜臀av性久久久久蜜臀aⅴ | 国产精品一区二区无码对白| 日韩欧美国产中文字幕| 蜜芽在线免费观看| 久久国产手机看片| 久久黄色级2电影| 国产超碰人人爽人人做人人爱| 色av吧综合网| 偷拍一区二区| 无码国产精品一区二区高潮|