版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
【移動應(yīng)用開發(fā)技術(shù)】Android中怎么升級SQLite數(shù)據(jù)庫版本
這篇文章給大家介紹Android中怎么升級SQLite數(shù)據(jù)庫版本,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。AndroidSQLite數(shù)據(jù)庫版本升級的管理實(shí)現(xiàn)我們知道在SQLiteOpenHelper的構(gòu)造方法:super(Context
context,
String
name,
SQLiteDatabase.CursorFactory
factory,
int
version)中最后一個參數(shù)表示數(shù)據(jù)庫的版本號.當(dāng)新的版本號大于當(dāng)前的version時會調(diào)用方法:onUpgrade(SQLiteDatabase
db,
int
oldVersion,
int
newVersion)所以我們的重點(diǎn)是在該方法中實(shí)現(xiàn)SQLite數(shù)據(jù)庫版本升級的管理當(dāng)我們項(xiàng)目剛開始的時候第一版SQLiteOpenHelper是這樣寫的:package
cc.database;
import
android.content.Context;
import
android.database.sqlite.SQLiteDatabase;
import
android.database.sqlite.SQLiteDatabase.CursorFactory;
import
android.database.sqlite.SQLiteOpenHelper;
/**
*
Demo描述:
*
SQLite數(shù)據(jù)庫版本升級的管理實(shí)現(xiàn)
*
*
參考資料:
*
/guolin_blog
*
Thank
you
very
much
*/
public
class
DataBaseOpenHelper
extends
SQLiteOpenHelper
{
private
final
static
String
DATABASE_NAME="test.db";
private
static
DataBaseOpenHelper
mDataBaseOpenHelper;
public
static
final
String
CREATE_PERSON=
"create
table
person(personid
integer
primary
key
autoincrement,name
varchar(20),phone
VARCHAR(12))";
public
DataBaseOpenHelper(Context
context,String
name,CursorFactory
factory,int
version)
{
super(context,
name,
factory,
version);
}
//注意:
//將DataBaseOpenHelper寫成單例的.
//否則當(dāng)在一個for循環(huán)中頻繁調(diào)用openHelper.getWritableDatabase()時
//會報錯,提示數(shù)據(jù)庫沒有執(zhí)行關(guān)閉操作
static
synchronized
DataBaseOpenHelper
getDBInstance(Context
context)
{
if
(mDataBaseOpenHelper
==
null)
{
mDataBaseOpenHelper
=
new
DataBaseOpenHelper(context,DATABASE_NAME,null,1);
}
return
mDataBaseOpenHelper;
}
@Override
public
void
onCreate(SQLiteDatabase
db)
{
db.execSQL(CREATE_PERSON);
}
@Override
public
void
onUpgrade(SQLiteDatabase
db,
int
oldVersion,
int
newVersion)
{
}
}在幾天之后根據(jù)項(xiàng)目需求,需要添加一張student表,于是DataBaseOpenHelper就出現(xiàn)了第二版:package
cc.database;
import
android.content.Context;
import
android.database.sqlite.SQLiteDatabase;
import
android.database.sqlite.SQLiteDatabase.CursorFactory;
import
android.database.sqlite.SQLiteOpenHelper;
public
class
DataBaseOpenHelper
extends
SQLiteOpenHelper
{
private
final
static
String
DATABASE_NAME="test.db";
private
static
DataBaseOpenHelper
mDataBaseOpenHelper;
public
static
final
String
CREATE_PERSON=
"create
table
person(personid
integer
primary
key
autoincrement,name
varchar(20),phone
VARCHAR(12))";
public
static
final
String
CREATE_STUDENT=
"create
table
student(studentid
integer
primary
key
autoincrement,name
varchar(20),phone
VARCHAR(12))";
public
DataBaseOpenHelper(Context
context,String
name,CursorFactory
factory,int
version)
{
super(context,
name,
factory,
version);
}
//注意:
//將DataBaseOpenHelper寫成單例的.
//否則當(dāng)在一個for循環(huán)中頻繁調(diào)用openHelper.getWritableDatabase()時
//會報錯,提示數(shù)據(jù)庫沒有執(zhí)行關(guān)閉操作
static
synchronized
DataBaseOpenHelper
getDBInstance(Context
context)
{
if
(mDataBaseOpenHelper
==
null)
{
//改動1
mDataBaseOpenHelper
=
new
DataBaseOpenHelper(context,DATABASE_NAME,null,2);
}
return
mDataBaseOpenHelper;
}
@Override
public
void
onCreate(SQLiteDatabase
db)
{
db.execSQL(CREATE_PERSON);
//改動2
db.execSQL(CREATE_STUDENT);
}
@Override
public
void
onUpgrade(SQLiteDatabase
db,
int
oldVersion,
int
newVersion)
{
//改動3
switch
(oldVersion)
{
case
1:
db.execSQL(CREATE_STUDENT);
default:
}
}
}較版本一在版本二中有三處修改的地方:1版本號變成了22在onCreate()方法中添加了代碼db.execSQL(CREATE_STUDENT);創(chuàng)建student表
因?yàn)橛械挠脩舾揪蜎]有第一版本的APP,直接從市場下載了第二版本的App。所以當(dāng)然會執(zhí)行onCreate()而不會執(zhí)行onUpgrade()3在onUpgrade()做了處理:當(dāng)oldVersion為1時調(diào)用db.execSQL(CREATE_STUDENT);創(chuàng)建student表
因?yàn)橛械挠脩羰謾C(jī)上本來就有第一版本的APP,所以在App升級到第二版本時會執(zhí)行onUpgrade(),不會執(zhí)行onCreate()通過這樣的處理使得不同的情況下使用第二版APP時都會生成student表又過了一個月,根據(jù)項(xiàng)目變更,需要給person表添加一個字段genderid,于是DataBaseOpenHelper就出現(xiàn)了第三版:package
cc.database;
import
android.content.Context;
import
android.database.sqlite.SQLiteDatabase;
import
android.database.sqlite.SQLiteDatabase.CursorFactory;
import
android.database.sqlite.SQLiteOpenHelper;
public
class
DataBaseOpenHelper
extends
SQLiteOpenHelper
{
private
final
static
String
DATABASE_NAME="test.db";
private
static
DataBaseOpenHelper
mDataBaseOpenHelper;
//改動1
public
static
final
String
CREATE_PERSON=
"create
table
person(personid
integer
primary
key
autoincrement,name
varchar(20),phone
VARCHAR(12)),genderid
integer)";
public
static
final
String
ALTER_PERSON="alter
table
person
add
column
genderid
integer";
public
static
final
String
CREATE_STUDENT=
"create
table
student(studentid
integer
primary
key
autoincrement,name
varchar(20),phone
VARCHAR(12))";
public
DataBaseOpenHelper(Context
context,String
name,CursorFactory
factory,int
version)
{
super(context,
name,
factory,
version);
}
//注意:
//將DataBaseOpenHelper寫成單例的.
//否則當(dāng)在一個for循環(huán)中頻繁調(diào)用openHelper.getWritableDatabase()時
//會報錯,提示數(shù)據(jù)庫沒有執(zhí)行關(guān)閉操作
static
synchronized
DataBaseOpenHelper
getDBInstance(Context
context)
{
if
(mDataBaseOpenHelper
==
null)
{
//改動2
mDataBaseOpenHelper
=
new
DataBaseOpenHelper(context,DATABASE_NAME,null,3);
}
return
mDataBaseOpenHelper;
}
@Override
public
void
onCreate(SQLiteDatabase
db)
{
db.execSQL(CREATE_PERSON);
db.execSQL(CREATE_STUDENT);
}
@Override
public
void
onUpgrade(SQLiteDatabase
db,
int
oldVersion,
int
newVersion)
{
switch
(oldVersion)
{
case
1:
db.execSQL(CREATE_STUDENT);
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 內(nèi)審和管理評審培訓(xùn)課件
- 手球指紋課件教學(xué)課件
- 營養(yǎng)門診課件教學(xué)課件
- 第三章第一節(jié)第二課時鐵鹽和亞鐵鹽高一上學(xué)期化學(xué)人教版(2019)必修第一冊
- 護(hù)理學(xué)科建設(shè)競聘
- 2.3.2氣體摩爾體積 課件 高一上學(xué)期化學(xué)人教版(2019)必修第一冊
- 新食品安全責(zé)任制度
- 沉與浮科學(xué)教案反思
- 化學(xué)反應(yīng)速率說課稿
- 好玩的沙子說課稿
- 2023年副主任醫(yī)師(副高)-耳鼻咽喉科學(xué)(副高)歷年考試真題(易錯與難點(diǎn)匯編)帶答案
- 21秋國家開放大學(xué)《公共部門人力資源管理》單元自測題參考答案
- 中藥的外治膏藥
- 小學(xué)數(shù)學(xué)專題講座(課堂PPT)
- 煤礦職業(yè)衛(wèi)生培訓(xùn)課件2023
- 傳染病報告與管理培訓(xùn)
- 丹參培育講義
- 高血壓原因待查疑難病例討論
- 通信工程基站鐵塔監(jiān)理規(guī)劃
- 教師成績進(jìn)步發(fā)言稿3篇
- ISO27001:2022信息安全管理手冊+全套程序文件+表單
評論
0/150
提交評論