设为首页 收藏本站
查看: 1054|回复: 0

[经验分享] 发布Sqlite数据库

[复制链接]

尚未签到

发表于 2016-11-29 11:04:46 | 显示全部楼层 |阅读模式
  
前言
  如何将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_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,但没有测试过,不知道后续的版本会不会改进这个数据库发布的问题。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307168-1-1.html 上篇帖子: VACUUM command in SQLite 下篇帖子: SQLite源码编译使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表