android中实现sqlite打包到APK发布
来源:互联网 发布:初中题库软件 编辑:程序博客网 时间:2024/05/16 09:23
源:http://blog.csdn.net/zurich1979/article/details/7341404
网上能找到很多这样的sqlite数据库打包随android应用发布的文章,
但是最少有80%以上应该都是直接转出来的,根本没有尝试操作过,
我这两天也在做数据库的打包工作,
在网上寻觅了好几篇,大同小异,代码相当,
但是整整试了两天多,代码都不好使,在代码里面加了不少日志,
但是都出现异常,我把最新总结的代码贴出来,供需要的参考。
功能:
正常的应用数据库放在/data/data/包名/database/test.db,应用发布时,这个数据库不会随着应用一起发布,
所以为了让我们已经准备好的数据正常使用,必须能实现数据库自身复制到sd卡下面,
实现拷贝res/raw/test.db下资源拷贝到SD卡下的/mnt/sdcard/test/test.db
代码如下:
package zcping.syan.DBDefinition;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import zcping.syan.DragonBaby.R;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
public class ReleaseDataBaseActivity{
/** Called when the activity is first created. */
//SD卡下的目录
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath() + "/db_exam";
//数据库名
private final String DATABASE_FILENAME = "db_exam.db";
//这个context是必需的,没有context,怎么都不能实现数据库的拷贝操作;
private Context context;
//构造函数必需传入Context,数据库的操作都带有这个参数的传入
public ReleaseDataBaseActivity(Context ctx) {
this.context = ctx;
}
public SQLiteDatabase OpenDataBase() {
try {
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
File dir = new File(DATABASE_PATH);
//判断SD卡下是否存在存放数据库的目录,如果不存在,新建目录
if (!dir.exists()) {
dir.mkdir();
Log.i("ReleaseDataBaseActivity", "dir made:" + DATABASE_PATH);
} else {
Log.i("ReleaseDataBaseActivity", "dir exist:" + DATABASE_PATH);
}
try {
//如果数据库已经在SD卡的目录下存在,那么不需要重新创建,否则创建文件,并拷贝/res/raw下面的数据库文件
if (!(new File(databaseFilename)).exists()) {
Log.i("ReleaseDataBaseActivity", "file not exist:"
+ databaseFilename);
///res/raw数据库作为输出流
InputStream is = this.context.getResources().openRawResource(
R.raw.db_exam);
//测试用
int size = is.available();
Log.i( "ReleaseDataBaseActivity", "DATABASE_SIZE:" + 1 );
Log.i("ReleaseDataBaseActivity", "count:" + 0);
//用于存放数据库信息的数据流
FileOutputStream fos = new FileOutputStream(
databaseFilename);
byte[] buffer = new byte[8192];
int count = 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 (FileNotFoundException e) {
Log.e("Database", "File not found");
e.printStackTrace();
} catch (IOException e) {
Log.e("Database", "IO exception");
e.printStackTrace();
}
//实例化sd卡上得数据库,database作为返回值,是后面所有插入,删除,查询操作的借口。
SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
databaseFilename, null);
return database;
} catch (Exception e) {
}
return null;
}
}
经过测试,绝对好使,希望对大家有帮助。
- android中实现sqlite打包到APK发布
- android中实现sqlite打包到APK发布
- android中实现sqlite打包到APK发布
- android 如何将数据库打包到apk中发布
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android开发中, 将apk和SQLite数据库一起打包发布 (没root手机)
- Android数据库SQLite文件打包,随APK发布
- Android 讲sqlite数据库打包同apk一同发布
- Android Studio打包.so到apk中
- Android Studio 打包发布apk
- Android中apk多渠道打包----友盟打包实现步骤
- android 把第三方apk打包到System.img中
- android 将三方jar包打包到apk中
- Android JNI以及打包so文件到apk中
- Android Studio打包.so库到apk中
- Android Studio打包.so库到apk中
- Mac OSX下安装使用定理证明器Z3
- 阿里腾讯参与
- sql面试题
- Codeforces Round #235 (Div. 2) ----D. Roman and Numbers
- 多线程服务器的典型适用场合
- android中实现sqlite打包到APK发布
- 一段代码
- 【STL】 map
- 多线程服务器的常用编程模型
- Gstreamer框架中使用gst-launch进行流媒体播放
- Java华丽转身 —— GUI编程宝典
- 适配ios7时使用edgesForExtendedLayout遇到的黑色背景问题
- Android NDK C++开发注意事项总结
- 文件的上传和下载以及如何防止网站被入侵(web开发中很有用的知识)