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

前端技术 2023/09/01 Android

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

复制代码 代码如下:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;

import com.ata.app.R;

/**
 * copy数据库到apk包
 *
 * @author NGJ
 *
 */
public class DataBaseUtil {

 private Context context;
 public static String dbName = \"Kao.db\";// 数据库的名字
 private static String DATABASE_PATH;// 数据库在手机里的路径

 public DataBaseUtil(Context context) {
  this.context = context;
  String packageName = context.getPackageName();
  DATABASE_PATH=\"/data/data/\"+packageName+\"/databases/\";
 }

 /**
  * 判断数据库是否存在
  *
  * @return false or true
  */
 public boolean checkDataBase() {
  SQLiteDatabase db = null;
  try {
   String databaseFilename = DATABASE_PATH + dbName;
   db = SQLiteDatabase.openDatabase(databaseFilename, null,SQLiteDatabase.OPEN_READONLY);
  } catch (SQLiteException e) {

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

 /**
  * 复制数据库到手机指定文件夹下
  *
  * @throws IOException
  */
 public void copyDataBase() throws IOException {
  String databaseFilenames = DATABASE_PATH + dbName;
  File dir = new File(DATABASE_PATH);
  if (!dir.exists())// 判断文件夹是否存在,不存在就新建一个
   dir.mkdir();
  FileOutputStream os = new FileOutputStream(databaseFilenames);// 得到数据库文件的写入流
  InputStream is = context.getResources().openRawResource(R.raw.kao);// 得到数据库文件的数据流
  byte[] buffer = new byte[8192];
  int count = 0;
  while ((count = is.read(buffer)) > 0) {
   os.write(buffer, 0, count);
   os.flush();
  }
  is.close();
  os.close();
 }
}

本文地址:https://www.stayed.cn/item/2659

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。