终端开发

使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 gradle相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

标签

android 46

Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 再说adb 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书) Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS adb Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 adb Base Command Android Log的那些坑…………

如何随apk一起打包并使用SQLite

2017年02月08日

背景

最近在开发摇吧的过程需要在应用发布的时候就顺便把应用相关的数据库一起发布,写完以后专门写了这篇文章总结一下。

准备数据库

创建数据表

  • 创建DB文件

    在shell中输入下面的命令创建db.

      ➜  1  sqlite3 shakeba.db
      SQLite version 3.9.2 2015-11-02 18:31:45
      Enter ".help" for usage hints.
    
  • 查看DB信息

    继续输入下面的命令,即可看到创建的db将会保存的位置,另外可以发现sqlite会默认创建名为main的数据库。

      sqlite> .databases
      seq  name             file
      ---  ---------------  ----------------------------------------------------------
      0    main             /Volumes/Document/Document/temp/1/shakeba.db
    
  • 关联DB

    开发中可能并不想直接用默认的数据库名,可以通过ATTACH关联自定义的名称。例如

      sqlite> ATTACH DATABASE 'shakeba.db' as shakeba;
      sqlite> .databases
      seq  name             file
      ---  ---------------  ----------------------------------------------------------
      0    main             /Volumes/Document/Document/temp/1/shakeba.db
      2    shakeba          /Volumes/Document/Document/temp/1/shakeba.db	 这样就可以按照自定义的数据库名来操作了。
    

添加数据

  • 添加默认表

    为了防止android程序出错,需要在shakeba.db中创建表android_metadata,并插入一行数据具体命令如下:

      sqlite> CREATE TABLE "android_metadata" ("locale" TEXT DEFAULT 'zh_CN');
      sqlite> INSERT INTO "android_metadata" VALUES ('zh_CN');
    

    通过查看表确实已经创建好,而且内容OK

      sqlite> .tables
      android_metadata
      sqlite> .header on
      sqlite> select * from android_metadata;
      locale
      zh_CN
    
  • 添加个人表

    这部分内容主要是添加应用相关的数据表,简单举例:

      DROP TABLE IF EXISTS "t_adventure";
      CREATE TABLE "t_adventure" (
          "id" INT PRIMARY KEY NOT NULL,
          "item_type" SMALLINT NOT NULL DEFAULT 1,
          "item_category" SMALLINT NOT NULL DEFAULT 1,
          "content" NVARCHAR(4096) NOT NULL DEFAULT ""
      );
    

    添加数据

      INSERT INTO "t_adventure" VALUES 
      (1,2,'1','背一位异性绕场一周'),
      (3,2,'1','做一个大家都满意的鬼脸'),
      (4,2,'2','抱一位异性直到下一轮真心话大冒险结束');
    

至此就已经完成了前期的数据库文件的准备。

定义版本号

为了保证二进制的数据文件与代码使用的一致,可以在二进制的数据文件中定义数据库的版本号,在应用初始化的时候对比版本号是否一致,如果一致再拷贝使用。

PRAGMA shakeba.user_version = 1;

集成数据库到APK

将前面创建好的数据库放在项目工程下源码的/res/raw路径下。至此我们就完成了前期的db的准备并添加到项目中,接下来就是数据处理相关的内容。

数据操作

拷贝DB

因为raw中的db无法直接访问,因此我们在应用初始化的时候要先把db拷贝到应用的私有目录 getApplicationContext().getDatabasePath(DATABASE_NAME)中。

  • 具体代码

      InputStream myInput = Shakeba.getInstance().getApplicationContext().getResources().openRawResource(getRawDatabaseResID());
    
      File file = Shakeba.getInstance().getApplicationContext().getDatabasePath(getDatabaseName());
    
      if (!file.exists()) {
          try {
              OutputStream myOutput = new FileOutputStream(file);
    
              byte[] buffer = new byte[1024];
              int length;
              while ((length = myInput.read(buffer))>0){
                  myOutput.write(buffer, 0, length);
              }
              myOutput.close();
              myInput.close();
              mIsDBOK = true;
          } catch (Exception e) {
              e.printStackTrace();
          }
      }
    
  • 代码位置

    在shakeba项目中,这部分逻辑在com.bihe0832.shakeba.framework.database.BaseRawDatabaseHelper中实现

增删改查

在上面的拷贝DB的动作完成以后,原本打包在APK中的db就已经拷贝到了应用私有目录下,此时对于数据库的增删改查的操作就和正常的使用SQLiteOpenHelper的操作一致了,因此不再特别说明。这部分内容可以参考shakeba项目的以下代码:

  • com.bihe0832.shakeba.framework.database.*
  • com.bihe0832.shakeba.module.game.adventure.AdventureTableModel


PS:我的博客即将搬运同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=10zhijuy24v4f

赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!