• Android 开发中,如何将 SQLite 和 APK 一起打包发布


    最近一时心血来潮,尝试开发 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/

  • 相关阅读:
    一个日期类型接口参数的构造思路
    python接口测试:如何将A接口的返回值传递给B接口
    关于查询类接口的一些总结
    (六十八)c#Winform自定义控件-DEMO整理-HZHControls
    (六十七)c#Winform自定义控件-柱状图-HZHControls
    (六十六)c#Winform自定义控件-图标-HZHControls
    (六十五)c#Winform自定义控件-思维导图/组织架构图(工业)-HZHControls
    (六十四)c#Winform自定义控件-温度计(工业)-HZHControls
    (六十三)c#Winform自定义控件-箭头(工业)-HZHControls
    (六十二)c#Winform自定义控件-警灯(工业)-HZHControls
  • 原文地址:https://www.cnblogs.com/gzggyy/p/2506121.html
Copyright © 2020-2023  润新知