zl程序教程

您现在的位置是:首页 >  移动开发

当前栏目

Android数据库打包随APK发布的实例代码

2023-06-13 09:15:06 时间

其实很简单,就是把我们的数据库文件放到我们的手机里,所以不必局限在哪个地方写这个代码,在第一次创建数据库的时候可以,我觉得在软件起动页里效果更好一点,首先我们应该把事先写好的数据库文件比如test.db放到res文件夹里的raw文件夹里,也可以放到assets里,因为这两个文件夹不会在生成APK的时候不会被压缩。
1,DataBaseUtil用于将raw中的db文件copy到手机中,代码如下

复制代码代码如下:

importjava.io.File;
importjava.io.FileOutputStream;
importjava.io.IOException;
importjava.io.InputStream;

importandroid.content.Context;
importandroid.database.sqlite.SQLiteDatabase;
importandroid.database.sqlite.SQLiteException;

importcom.ata.app.R;

/**
 *copy数据库到apk包
 *
 *@authorNGJ
 *
 */
publicclassDataBaseUtil{

 privateContextcontext;
 publicstaticStringdbName="Kao.db";//数据库的名字
 privatestaticStringDATABASE_PATH;//数据库在手机里的路径

 publicDataBaseUtil(Contextcontext){
  this.context=context;
  StringpackageName=context.getPackageName();
  DATABASE_PATH="/data/data/"+packageName+"/databases/";
 }

 /**
 *判断数据库是否存在
 *
 *@returnfalseortrue
 */
 publicbooleancheckDataBase(){
  SQLiteDatabasedb=null;
  try{
   StringdatabaseFilename=DATABASE_PATH+dbName;
   db=SQLiteDatabase.openDatabase(databaseFilename,null,SQLiteDatabase.OPEN_READONLY);
  }catch(SQLiteExceptione){

  }
  if(db!=null){
   db.close();
  }
  returndb!=null?true:false;
 }

 /**
 *复制数据库到手机指定文件夹下
 *
 *@throwsIOException
 */
 publicvoidcopyDataBase()throwsIOException{
  StringdatabaseFilenames=DATABASE_PATH+dbName;
  Filedir=newFile(DATABASE_PATH);
  if(!dir.exists())//判断文件夹是否存在,不存在就新建一个
   dir.mkdir();
  FileOutputStreamos=newFileOutputStream(databaseFilenames);//得到数据库文件的写入流
  InputStreamis=context.getResources().openRawResource(R.raw.kao);//得到数据库文件的数据流
  byte[]buffer=newbyte[8192];
  intcount=0;
  while((count=is.read(buffer))>0){
   os.write(buffer,0,count);
   os.flush();
  }
  is.close();
  os.close();
 }
}


2,在需要的activity中加入如下方法用于具体的copy操作
复制代码代码如下:

Java代码 
privatevoidcopyDataBaseToPhone(){ 
       DataBaseUtilutil=newDataBaseUtil(this); 
       //判断数据库是否存在 
       booleandbExist=util.checkDataBase(); 

       if(dbExist){ 
           Log.i("tag","Thedatabaseisexist."); 
       }else{//不存在就把raw里的数据库写入手机 
           try{ 
              util.copyDataBase(); 
          }catch(IOExceptione){ 
              thrownewError("Errorcopyingdatabase"); 
          } 
       } 
   } 


3,检测是否有SDCard,执行copy。(个人感觉可以不检测SD卡是否存在,但不检测似乎有个问题,程序原因?)

复制代码代码如下:
booleanhasSDCard=Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED);
  if(hasSDCard){
   copyDataBaseToPhone();
  }else{
   showToast("未检测到SDCard");
  }