[Android]发布Sqlite数据库
2010-08-11 16:36
260 查看
前言
如何将Sqlite数据库与apk一同发布?刚开始用时有朋友告诉我直接用adb命令手工发布,或者写sql语句动态创建,感觉不太理想。得益于银河使者的实现基于Android的英文电子词典这篇文章,再经过文章2的补充以及实践得以完成,感谢大家的分享!
文章
1. 实现基于Android的英文电子词典
2. Using your own SQLite database in Android applications
3. Android Asset,res/raw限制文件大小UNCOMPRESS为1MB
声明
欢迎转载,但请保留文章原始出处:)
农民伯伯: http://over140.blog.51cto.com/
正文
一、准备
1.1 准备目录
在Android项目工程res下新建raw文件夹,在这个文件夹里面的文件不会被编译压缩。
1.2 准备数据库
新建或拷贝一个数据库,然后打开,依次执行以下两条SQL语句:
CREATE TABLE "android_metadata" ("locale" TEXT DEFAULT 'zh_CN')
INSERT INTO "android_metadata" VALUES ('zh_CN')
这个表用途不太清楚,但是如果用Android sqlite API创建一个数据库的话,会默认带上这个表,而且少了还不行,会报错。
二、实现代码
/**
* 是否完成初始化
*/
private static boolean isInit = false;
/**
* 初始化数据库
* @param context
*/
synchronized public static void init(Context context)
{
if(isInit)
return;
// 输出路径
String outFileName = DATABASE_PATH + DATABASE_NAME;
//检测是否已经创建
File dir = new File(outFileName);
if(dir.exists())
return;
// 检测/创建数据库的文件夹
dir = new File(DATABASE_PATH);
if (!dir.exists())
dir.mkdir();
InputStream input = null;
OutputStream output = null;
// 从资源中读取数据库流
input = context.getResources().openRawResource(R.raw.db);
try {
output = new FileOutputStream(outFileName);
// 拷贝到输出流
byte[] buffer = new byte[2048];
int length;
while ((length = input.read(buffer)) > 0) {
output.write(buffer, 0, length);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 关闭输出流
try {
output.flush();
output.close();
} catch (IOException e) {
}
// 关闭输入流
try {
input.close();
} catch (IOException e) {
}
}
isInit = true;
}
代码说明:
a). 在主窗口(Activity)中调用一次即可,随后直接用SQLiteDatabase.openDatabase操作使用即可。
结束
注意文章3,但没有测试过,不知道后续的版本会不会改进这个数据库发布的问题。
如何将Sqlite数据库与apk一同发布?刚开始用时有朋友告诉我直接用adb命令手工发布,或者写sql语句动态创建,感觉不太理想。得益于银河使者的实现基于Android的英文电子词典这篇文章,再经过文章2的补充以及实践得以完成,感谢大家的分享!
文章
1. 实现基于Android的英文电子词典
2. Using your own SQLite database in Android applications
3. Android Asset,res/raw限制文件大小UNCOMPRESS为1MB
声明
欢迎转载,但请保留文章原始出处:)
农民伯伯: http://over140.blog.51cto.com/
正文
一、准备
1.1 准备目录
在Android项目工程res下新建raw文件夹,在这个文件夹里面的文件不会被编译压缩。
1.2 准备数据库
新建或拷贝一个数据库,然后打开,依次执行以下两条SQL语句:
CREATE TABLE "android_metadata" ("locale" TEXT DEFAULT 'zh_CN')
INSERT INTO "android_metadata" VALUES ('zh_CN')
这个表用途不太清楚,但是如果用Android sqlite API创建一个数据库的话,会默认带上这个表,而且少了还不行,会报错。
二、实现代码
/**
* 是否完成初始化
*/
private static boolean isInit = false;
/**
* 初始化数据库
* @param context
*/
synchronized public static void init(Context context)
{
if(isInit)
return;
// 输出路径
String outFileName = DATABASE_PATH + DATABASE_NAME;
//检测是否已经创建
File dir = new File(outFileName);
if(dir.exists())
return;
// 检测/创建数据库的文件夹
dir = new File(DATABASE_PATH);
if (!dir.exists())
dir.mkdir();
InputStream input = null;
OutputStream output = null;
// 从资源中读取数据库流
input = context.getResources().openRawResource(R.raw.db);
try {
output = new FileOutputStream(outFileName);
// 拷贝到输出流
byte[] buffer = new byte[2048];
int length;
while ((length = input.read(buffer)) > 0) {
output.write(buffer, 0, length);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 关闭输出流
try {
output.flush();
output.close();
} catch (IOException e) {
}
// 关闭输入流
try {
input.close();
} catch (IOException e) {
}
}
isInit = true;
}
代码说明:
a). 在主窗口(Activity)中调用一次即可,随后直接用SQLiteDatabase.openDatabase操作使用即可。
结束
注意文章3,但没有测试过,不知道后续的版本会不会改进这个数据库发布的问题。
相关文章推荐
- Android开发中, 将apk和SQLite数据库一起打包发布 (没root手机)
- 随Android程序发布SQLite数据库
- android绑定sqlite数据库与程序一起发布
- android绑定sqlite数据库与程序一起发布
- [Android]发布Sqlite数据库
- Android菜鸟笔记-SQLite数据库和APK一起发布
- [Android]发布Sqlite数据库
- Android -- sqlite数据库随apk发布
- Android 讲sqlite数据库打包同apk一同发布
- Android 使用SQLite数据库
- 【转】Android查看sqlite数据库内容的方法
- Android 发布到jcenter遇到的坑(附升级gradle4.1后的新问题)
- Android开发(10)使用SQLiteDatabase操作SQLite数据库实现增删改查(源码)
- ShareSDK for Android版本:V2.3.12发布
- 05_android入门_sqlite数据库创建
- [Android]发布自己的项目库到jcenter
- EnevtBus 发布、订阅消息--android
- 双屏电子书Alex产品发布了,E-INK电纸屏+Android
- 震撼发布2017年Android百大框架排行榜
- Android开发之SQLite数据库