[Android]发表Sqlite数据库

前言

  咋样将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://www.cnblogs.com

    农民三伯: http://www.cnblogs.com/over140/   

 

正文

  一、准备

    1.1  准备目录

      在Android项目工程res下新建raw文件夹,在这几个文件夹里面的文件不会被编译压缩。

    1.2  准备数据库

      新建或拷贝一个数据库,然后打开,依次执行以下两条SQL语句:

CREATE TABLE “android_metadata” (“locale” TEXT DEFAULT ‘zh_CN’)

INSERT INTO “android_sqlite,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,但尚未测试过,不晓得后续的版本会不会改进那个数据库发布的难点。

网站地图xml地图