Android 开发中,如何将 SQLite 和 APK 一起打包发布
来源:互联网 发布:visual studio c编程 编辑:程序博客网 时间:2024/04/29 23:23
最近一时心血来潮,尝试开发 Android 程序,练习的项目是个简单的天气预报程序。其中天气预报自然要涉及全国各地各个地区,我把这些地区名以及地区代码放在一个 SQLite 数据库里,当然 Android 对 SQLite 也支持的很好。问题是,学习过程中发现很多教程或者示例,都是程序运行后即时创建一个数据库,然后建表、插入数据什么的,而我自己的想法是在电脑上把数据库事先准备好,然后随 APK 一起打包发布,否则在 Java 代码里面 hard code 几千条 insert 语句,显然是很傻瓜的行为。经过多方网络搜寻,终于找到比较完善的解决方法。
在 Eclipse 里新建好工程后,默认会有一个 assets
目录,在 Eclipse 中直接将准备好的 SQLite 数据库复制到该目录中,然后在主 Activity 里面编码:
package com.test.db;import java.io.File;import java.io.FileOutputStream;import java.io.InputStream;import java.io.OutputStream;import java.io.UnsupportedEncodingException;import android.app.Activity;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.os.Bundle;public class DbtestActivity extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); // com.test.db 是程序的包名,请根据自己的程序调整 // /data/data/com.test.db/ // databases 目录是准备放 SQLite 数据库的地方,也是 Android 程序默认的数据库存储目录 // 数据库名为 test.db String DB_PATH = "/data/data/com.test.db/databases/"; String DB_NAME = "test.db"; // 检查 SQLite 数据库文件是否存在 if ((new File(DB_PATH + DB_NAME)).exists() == false) { // 如 SQLite 数据库文件不存在,再检查一下 database 目录是否存在 File f = new File(DB_PATH); // 如 database 目录不存在,新建该目录 if (!f.exists()) { f.mkdir(); } try { // 得到 assets 目录下我们实现准备好的 SQLite 数据库作为输入流 InputStream is = getBaseContext().getAssets().open(DB_NAME); // 输出流 OutputStream os = new FileOutputStream(DB_PATH + DB_NAME); // 文件写入 byte[] buffer = new byte[1024]; int length; while ((length = is.read(buffer)) > 0) { os.write(buffer, 0, length); } // 关闭文件流 os.flush(); os.close(); is.close(); } catch (Exception e) { e.printStackTrace(); } } // 下面测试 /data/data/com.test.db/databases/ 下的数据库是否能正常工作 SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(DB_PATH + DB_NAME, null); Cursor cursor = database.rawQuery("select * from test", null); if (cursor.getCount() > 0) { cursor.moveToFirst(); try { // 解决中文乱码问题 byte test[] = cursor.getBlob(0); String strtest = new String(test, "utf-8").trim(); // 看输出的信息是否正确 System.out.println(strtest); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } cursor.close(); }}
出处:http://www.akasuna.com/2012/03/09/embed-sqlite-database-in-the-apk-of-android-distributed-application/
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- Android开发中, 将apk和SQLite数据库一起打包发布 (没root手机)
- 如何将SQLite数据库与apk文件一起发布
- 如何将SQLite数据库与apk文件一起发布
- android 如何将数据库打包到apk中发布
- Android菜鸟笔记-SQLite数据库和APK一起发布
- sqlite和apk一起打包分析
- android中实现sqlite打包到APK发布
- android中实现sqlite打包到APK发布
- android中实现sqlite打包到APK发布
- 如何将SQLite数据库(dictionary.db文件)与apk文件一起发布
- 如何将SQLite数据库(dictionary.db文件)与apk文件一起发布
- 如何将SQLite数据库(dictionary.db文件)与apk文件一起发布
- 如何将带数据的SQLite数据与apk程序一起发布
- 如何将SQLite数据库(dictionary.db文件)与apk文件一起发布
- 如何将SQLite数据库(dictionary.db文件)与apk文件一起发布
- java编程基础
- WinCE下的C#开发,备忘录
- 黑马程序员_毕向东_Java基础_DAY03_循环控制_学习笔记
- [unity基础知识]之Unity3d之Vector3 学习与应用
- 顺序容器:vector的自增长特性
- Android 开发中,如何将 SQLite 和 APK 一起打包发布
- GIT 初学笔记--建立一个项目
- [leetcode]Distinct Subsequences
- 职业性格类型
- 将MATLAB数据保存到Excel中
- pdu 7bit 编码
- JDBC连接SQL Server2008
- 关于ORBACUS产品网络通讯函数出现的问题
- A FLASH Bootloader for PIC16 and PIC18 Devices--硬译(三)