博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android -- sqlite数据库随apk发布
阅读量:4615 次
发布时间:2019-06-09

本文共 2116 字,大约阅读时间需要 7 分钟。

背景                                                                                           

把在工程中测试好的数据库信息碎apk一起发布,但是数据库不会自动安装,尤其里面内容很多的时候,不可能再去每个apk里面再写创建数据库,再写插入数据。

那么这样的话只能将写工程时候的数据库sqlite随apk一起发布了。

要点                                                                                            

  • 将随apk发布的数据库放在android工程下/res/raw路径下。
  • 数据库文件存到手机上时,路径在/data/data/包名/databases下,其他路径则会出错。

代码                                                                                            

public class TestSqlDatabase{        private static final String DATABASE_PATH = "/data/data/your.package.name/databases";    private static final int DATABASE_VERSION = 0;    private static final String DATABASE_NAME = "test.db";        private static String outFileName = DATABASE_PATH + "/" + DATABASE_NAME;        private Context context;   private SQLiteDatabase database;        public TestSqlDatabase(Context context) {        this.context = context;                File file = new File(outFileName);        if (file.exists()) {            database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);            if (database.getVersion() != DATABASE_VERSION) {                database.close();                file.delete();                }        }        try {            buildDatabase();        } catch (Exception e) {            e.printStackTrace();        }            }    private void buildDatabase() throws Exception{        InputStream myInput = context.getResources().openRawResource(R.raw.test);        File file = new File(outFileName);                File dir = new File(DATABASE_PATH);        if (!dir.exists()) {            if (!dir.mkdir()) {                throw new Exception("创建失败");            }        }                if (!file.exists()) {                        try {                OutputStream myOutput = new FileOutputStream(outFileName);                                byte[] buffer = new byte[1024];                int length;                while ((length = myInput.read(buffer))>0){                    myOutput.write(buffer, 0, length);                }                myOutput.close();                myInput.close();            } catch (Exception e) {                e.printStackTrace();            }                }    }}

我是天王盖地虎的分割线                                                                 

这也就是一个IO流的控制,与《》有着异曲同工之妙。

《Android -- 拷贝assets下的资源文件到SD卡中(可以超过1M)》传送门:

 

 

转载请注明出处:

转载于:https://www.cnblogs.com/yydcdut/p/3783176.html

你可能感兴趣的文章
iOS: sqlite数据库的基本操作
查看>>
Silverlight图表开源项目-OxyPlot
查看>>
OPENCV学习笔记2-6_简单的图像运算
查看>>
bash随笔
查看>>
"%s"
查看>>
jquery刷新页面
查看>>
杭电1096
查看>>
Oracle中的 UPDATE FROM 解决方法
查看>>
鼠标经过图像改变实现
查看>>
二分查找法
查看>>
Spring3升级到Spring4时, 运行时出现找不到MappingJacksonHttpMessageConverter的情况
查看>>
详解缓冲区溢出攻击以及防范方法
查看>>
分布式事务解决方案(一) 2阶段提交 & 3阶段提交 & TCC
查看>>
android之网格布局和线性布局实现注册页面
查看>>
BZOJ 1014: [JSOI2008]火星人prefix( splay + hash )
查看>>
js /jq 写 全选 反选 不选
查看>>
spring + springmvc + jdbc + quartz + maven整合
查看>>
Android EditText 应用小小结
查看>>
关于分布式事务的读书笔记
查看>>
回调函数通俗解析(之前看了很久都不理解,今天终于ok啦)
查看>>