日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

android sqlitejian监听,tencent/sqlite.md · zhoujian/AndroidInterView - Gitee.com

發布時間:2025/3/15 Android 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android sqlitejian监听,tencent/sqlite.md · zhoujian/AndroidInterView - Gitee.com 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

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

>

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

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

應用中怎么檢測數據庫需要升級呢? SQLiteOpenHelper 類中有一個方法

```

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

```

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

##### 數據庫升級

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();

```

##### 數據庫的遷移

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

1、 將表名改成臨時表

ALTER TABLE Order RENAME TO _Order;

2、創建新表

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

>

3、導入數據

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

>

4、刪除臨時表

> DROPTABLE _Order;

>

通過以上四個步驟,就可以完成舊數據庫結構向新數據庫結構的遷移,并且其中還可以保證數據不會因為升級而流失。

當然,如果遇到減少字段的情況,也可以通過創建臨時表的方式來實現。

實現代碼如下

```

@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();

}

}

```

##### 多個數據庫版本的升級

假如我們開發的程序已經發布了兩個版本:V1.0,V2.0,我們正在開發V3.0。版本號分別是1,2,3。對于這種情況,我們應該如何實現升級?

用戶的選擇有:

> 1) V1.0 -> V3.0 DB 1 -> 2

> 2) V2.0 -> V3.0 DB 2 -> 3

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

> V1.0 —> TableA, TableB

> V1.2 —> TableA, TableB, TableC

> V1.3 —> 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;

}

}

```

##### 導入已有數據庫

```

/**

* 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();

}

}

}

}

```

##### 調用方式

```

@Override

protected void onResume() {

super.onResume();

DbManager dbManager = new DbManager(this);

dbManager.importDB();

SQLiteDatabase db = dbManager.openDataBase();

db.execSQL("do what you want");

}

```

一鍵復制

編輯

Web IDE

原始數據

按行查看

歷史

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的android sqlitejian监听,tencent/sqlite.md · zhoujian/AndroidInterView - Gitee.com的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品无码99re | 超碰伊人网| 成人激情开心网 | 国产一区欧美一区 | 女性喷水视频 | 国产一级特黄毛片 | 日本一区二区三区视频在线观看 | 人妻少妇精品无码专区二区 | zzjj国产精品一区二区 | 91无毒不卡 | 嫩草av91| 欧美日韩一区二区在线观看视频 | 国产麻豆91视频 | 国产又爽又黄游戏 | 精品一区免费 | 亚洲精品2区 | 亚洲熟女综合一区二区三区 | 黄色动漫软件 | 豆花在线观看 | 激情内射人妻1区2区3区 | 日本一区中文 | 黄色在线播放网站 | 红杏出墙记 | 牲欲强的熟妇农村老妇女视频 | 免费观看成人鲁鲁鲁鲁鲁视频 | 久久免费视频2 | 天天舔天天舔 | 丁香六月激情综合 | 国产精品3p视频 | julia一区二区中文久久97 | 欧美三级影院 | 丰满少妇大力进入 | 国产精品香蕉在线 | 国产香蕉精品视频 | 国产一区二区三区成人 | 日本毛片在线看 | 99碰碰| 91二区 | 午夜整容室 | 国产伦精品一区二区三区免费迷 | 男人天堂中文字幕 | 欧美日韩免费在线视频 | 欧美精品乱码视频一二专区 | 亚洲综合色在线 | 日日日日日日bbbbbb | 少妇光屁股影院 | 嫩草视频一区二区三区 | 亚洲免费在线视频 | 99久久影院 | 欧美 日韩 国产在线 | 97香蕉久久夜色精品国产 | 毛片在线视频 | 天天视频黄 | 亚洲精品色午夜无码专区日韩 | 亚洲免费在线观看视频 | 亚洲精品成a人在线观看 | 中文字幕在线视频免费播放 | 午夜免费福利在线 | 欧美精品一区二区三区四区 | 国内精品视频一区二区三区 | 国产高潮视频在线观看 | 成人性爱视频在线观看 | 天堂av免费观看 | 97在线国产 | av不卡网站| 日韩www.| 亚洲四区在线 | av免费在线观看网站 | 欧洲亚洲视频 | 亚洲第一a| 精品视频一区二区三区四区五区 | 91中文字幕在线观看 | 九九热在线视频免费观看 | 色呦呦网站在线观看 | 国产经典三级在线 | 欧美色亚洲色 | 亚洲三页| 女女h百合无遮涩涩漫画软件 | 超碰人人超 | 一区二区三区高清在线 | 亚洲精品一二三 | 亚洲成人一二三 | 成人久草| 精品中出| 女人下部全棵看视频 | 欧美成一区二区三区 | 亚洲九九视频 | 日本xxxxxxxxx18| 精品无码久久久久久久久成人 | 脱美女衣服亲摸揉视频 | 亚洲不卡av一区二区 | 草草影院1 | 国产免费激情视频 | 人碰人操 | 97人妻精品一区二区三区免费 | 九九综合网 | 91直接看| 日韩欧美视频在线 | 91成人在线观看喷潮 |