Android应用开发之将SQLite和APK一起打包的方法
在Eclipse里新建好工程后,默认会有一个assets目录,在Eclipse中直接将准备好的SQLite数据库复制到该目录中,然后在主Activity里面编码:
packagecom.test.db;
importjava.io.File;
importjava.io.FileOutputStream;
importjava.io.InputStream;
importjava.io.OutputStream;
importjava.io.UnsupportedEncodingException;
importandroid.app.Activity;
importandroid.database.Cursor;
importandroid.database.sqlite.SQLiteDatabase;
importandroid.os.Bundle;
publicclassDbtestActivityextendsActivity{
/**Calledwhentheactivityisfirstcreated.*/
@Override
publicvoidonCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//com.test.db是程序的包名,请根据自己的程序调整
///data/data/com.test.db/
//databases目录是准备放SQLite数据库的地方,也是Android程序默认的数据库存储目录
//数据库名为test.db
StringDB_PATH="/data/data/com.test.db/databases/";
StringDB_NAME="test.db";
//检查SQLite数据库文件是否存在
if((newFile(DB_PATH+DB_NAME)).exists()==false){
//如SQLite数据库文件不存在,再检查一下database目录是否存在
Filef=newFile(DB_PATH);
//如database目录不存在,新建该目录
if(!f.exists()){
f.mkdir();
}
try{
//得到assets目录下我们实现准备好的SQLite数据库作为输入流
InputStreamis=getBaseContext().getAssets().open(DB_NAME);
//输出流
OutputStreamos=newFileOutputStream(DB_PATH+DB_NAME);
//文件写入
byte[]buffer=newbyte[1024];
intlength;
while((length=is.read(buffer))>0){
os.write(buffer,0,length);
}
//关闭文件流
os.flush();
os.close();
is.close();
}catch(Exceptione){
e.printStackTrace();
}
}
//下面测试/data/data/com.test.db/databases/下的数据库是否能正常工作
SQLiteDatabasedatabase=SQLiteDatabase.openOrCreateDatabase(DB_PATH+DB_NAME,null);
Cursorcursor=database.rawQuery("select*fromtest",null);
if(cursor.getCount()>0){
cursor.moveToFirst();
try{
//解决中文乱码问题
bytetest[]=cursor.getBlob(0);
Stringstrtest=newString(test,"utf-8").trim();
//看输出的信息是否正确
System.out.println(strtest);
}catch(UnsupportedEncodingExceptione){
//TODOAuto-generatedcatchblock
e.printStackTrace();
}
}
cursor.close();
}
}
程序启动时候回去检查数据库文件在不在,如果不存在,就会把我们准备好的数据库复制到哪个databases目录下,而且如果用户卸载了这个程序,那么这个目录和数据库也将随之卸载。
再来一个示例。
正常的应用数据库放在/data/data/包名/database/test.db,应用发布时,这个数据库不会随着应用一起发布,
所以为了让我们已经准备好的数据正常使用,必须能实现数据库自身复制到sd卡下面,
实现拷贝res/raw/test.db下资源拷贝到SD卡下的/mnt/sdcard/test/test.db
代码如下:
packagezcping.syan.DBDefinition;
importjava.io.File;
importjava.io.FileNotFoundException;
importjava.io.FileOutputStream;
importjava.io.IOException;
importjava.io.InputStream;
importzcping.syan.DragonBaby.R;
importandroid.content.Context;
importandroid.database.sqlite.SQLiteDatabase;
importandroid.util.Log;
publicclassReleaseDataBaseActivity{
/**Calledwhentheactivityisfirstcreated.*/
//SD卡下的目录
privatefinalStringDATABASE_PATH=android.os.Environment
.getExternalStorageDirectory().getAbsolutePath()+"/db_exam";
//数据库名
privatefinalStringDATABASE_FILENAME="db_exam.db";
//这个context是必需的,没有context,怎么都不能实现数据库的拷贝操作;
privateContextcontext;
//构造函数必需传入Context,数据库的操作都带有这个参数的传入
publicReleaseDataBaseActivity(Contextctx){
this.context=ctx;
}
publicSQLiteDatabaseOpenDataBase(){
try{
StringdatabaseFilename=DATABASE_PATH+"/"+DATABASE_FILENAME;
Filedir=newFile(DATABASE_PATH);
//判断SD卡下是否存在存放数据库的目录,如果不存在,新建目录
if(!dir.exists()){
dir.mkdir();
Log.i("ReleaseDataBaseActivity","dirmade:"+DATABASE_PATH);
}else{
Log.i("ReleaseDataBaseActivity","direxist:"+DATABASE_PATH);
}
try{
//如果数据库已经在SD卡的目录下存在,那么不需要重新创建,否则创建文件,并拷贝/res/raw下面的数据库文件
if(!(newFile(databaseFilename)).exists()){
Log.i("ReleaseDataBaseActivity","filenotexist:"
+databaseFilename);
///res/raw数据库作为输出流
InputStreamis=this.context.getResources().openRawResource(
R.raw.db_exam);
//测试用
intsize=is.available();
Log.i("ReleaseDataBaseActivity","DATABASE_SIZE:"+1);
Log.i("ReleaseDataBaseActivity","count:"+0);
//用于存放数据库信息的数据流
FileOutputStreamfos=newFileOutputStream(
databaseFilename);
byte[]buffer=newbyte[8192];
intcount=0;
Log.i("ReleaseDataBaseActivity","count:"+count);
//把数据写入SD卡目录下
while((count=is.read(buffer))>0){
fos.write(buffer,0,count);
}
fos.flush();
fos.close();
is.close();
}
}catch(FileNotFoundExceptione){
Log.e("Database","Filenotfound");
e.printStackTrace();
}catch(IOExceptione){
Log.e("Database","IOexception");
e.printStackTrace();
}
//实例化sd卡上得数据库,database作为返回值,是后面所有插入,删除,查询操作的借口。
SQLiteDatabasedatabase=SQLiteDatabase.openOrCreateDatabase(
databaseFilename,null);
returndatabase;
}catch(Exceptione){
}
returnnull;
}
}
经过测试,绝对好使,希望对大家有帮助。