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; } }
经过测试,绝对好使,希望对大家有帮助。