android:Android中用文件初始化sqlite数据库(zz)

    很多时候在应用安装初始化时,需要创建本地数据库,同时为数据库添加数据,之后再从数据库中读取数据。

这里有2个思路

    1.先在本地创建一个能支持android使用的sqlite数据库文件,启动时,用现成的sqlite的二进制文件进行直接copy到Android系统的数据库路径

    2.可以考虑在第一次启动时,执行数据库初始化的sql文件.

 

1.在本地准备android能使用的sqlite数据库文件

使用sqlite数据库管理工具,看个人爱好(SQLite Database Browser ,Navicat Premium,)

打开数据库,创建"android_metadata"数据表

Sql代码  收藏代码
  1. CREATE TABLE "android_metadata" ("_id"  INTEGER PRIMARY KEY AUTOINCREMENT,"locale" TEXT DEFAULT 'en_US');//创建表  
  2. INSERT INTO "android_metadata" VALUES (1,'en_US');//插入值  

 创建其他应用需要的表..此处省略.

 

2.复制文件到应用中.

把第一步创建的数据库文件复制到应用中的assets文件夹, asserts文件夹的路径如下:

12617-20170515220055244-1567620136.png

然后创建DateBaseHelper extends SQLiteOpenHelper的类文件.

代码如下:

Java代码  收藏代码
  1. public class DataBaseHelper extends SQLiteOpenHelper {  
  2.     //The Android's default system path of your application database.  
  3.     private static String DB_PATH = "/data/data/YOUR_PACKAGE/databases/";  
  4.     private static String DB_NAME = "myDBName";  
  5.     private SQLiteDatabase myDataBase;  
  6.     private final Context myContext;  
  7.     /** 
  8.      * Constructor 
  9.      * Takes and keeps a reference of the passed context in order to access to the application assets and resources. 
  10.      * @param context 
  11.      */  
  12.     public DataBaseHelper(Context context) {  
  13.         super(context, DB_NAME, null1);  
  14.         this.myContext = context;  
  15.     }  
  16.   
  17.     /** 
  18.      * Creates a empty database on the system and rewrites it with your own database. 
  19.      * */  
  20.     public void createDataBase()throws IOException {  
  21.         boolean dbExist = checkDataBase();  
  22.         if (dbExist) {  
  23.             //do nothing - database already exist  
  24.         } else {  
  25.             //By calling this method and empty database will be created into the default system path  
  26.             //of your application so we are gonna be able to overwrite that database with our database.  
  27.             this.getReadableDatabase();  
  28.             try {  
  29.                 copyDataBase();  
  30.             } catch (IOException e) {  
  31.                 throw new Error("Error copying database");  
  32.             }  
  33.         }  
  34.     }  
  35.   
  36.     /** 
  37.      * Check if the database already exist to avoid re-copying the file each time you open the application. 
  38.      * @return true if it exists, false if it doesn't 
  39.      */  
  40.     private boolean checkDataBase() {  
  41.         SQLiteDatabase checkDB = null;  
  42.         try {  
  43.             String myPath = DB_PATH + DB_NAME;  
  44.             checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);  
  45.         } catch (SQLiteException e) {  
  46.             //database does't exist yet.  
  47.         }  
  48.   
  49.         if (checkDB != null) {  
  50.             checkDB.close();  
  51.         }  
  52.         return checkDB != null ? true : false;  
  53.     }  
  54.   
  55.     /** 
  56.      * Copies your database from your local assets-folder to the just created empty database in the 
  57.      * system folder, from where it can be accessed and handled. 
  58.      * This is done by transfering bytestream. 
  59.      * */  
  60.     private void copyDataBase()throws IOException {  
  61.         //Open your local db as the input stream  
  62.         InputStream myInput = myContext.getAssets().open(DB_NAME);  
  63.         // Path to the just created empty db  
  64.         String outFileName = DB_PATH + DB_NAME;  
  65.         //Open the empty db as the output stream  
  66.         OutputStream myOutput = new FileOutputStream(outFileName);  
  67.         //transfer bytes from the inputfile to the outputfile  
  68.         byte[]buffer = new byte[1024];  
  69.         int length;  
  70.         while ((length = myInput.read(buffer)) > 0) {  
  71.             myOutput.write(buffer, 0, length);  
  72.         }  
  73.   
  74.         //Close the streams  
  75.         myOutput.flush();  
  76.         myOutput.close();  
  77.         myInput.close();  
  78.     }  
  79.   
  80.     public void openDataBase()throws SQLException {  
  81.         //Open the database  
  82.         String myPath = DB_PATH + DB_NAME;  
  83.         myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);  
  84.     }  
  85.   
  86.     @Override  
  87.     public synchronized void close() {  
  88.         if (myDataBase != null)  
  89.             myDataBase.close();  
  90.         super.close();  
  91.     }  
  92.   
  93.     @Override  
  94.     public void onCreate(SQLiteDatabase db) {}  
  95.   
  96.     @Override  
  97.     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}  
  98.     // Add your public helper methods to access and get content from the database.  
  99.     // You could return cursors by doing "return myDataBase.query(....)" so it'd be easy  
  100.     // to you to create adapters for your views.  
  101. }  

 

3.现在我们可以创建DateBaseHelper的实现操作了.

createDataBase() //创建

openDataBase()//打开只读数据库

记得要更改"YOUR_PACKAGE"为你的应用的包名

如:com.examplename.myapp

大概代码如下:

Java代码  收藏代码
  1. ...  
  2. DataBaseHelper myDbHelper = new DataBaseHelper();  
  3. myDbHelper = new DataBaseHelper(this);  
  4. try {  
  5.     myDbHelper.createDataBase();  
  6. catch (IOException ioe) {  
  7.     throw new Error("Unable to create database");  
  8. }  
  9. try {  
  10.     myDbHelper.openDataBase();  
  11. catch (SQLException sqle) {  
  12.     throw sqle;  
  13. }  
  14. ...  
    来源: http://zhangfan822.iteye.com/blog/1883829

转载于:https://www.cnblogs.com/strinkbug/p/6858702.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572459.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面向对象-继承

继承: 概念: 继承父类的属性和行为,使得子类对象可以直接具有与父类相同的属性、相同的行为。子类可以直接访问父类中的非私有的属性和行为。继承是多态的前提,如果没有继承,就没有多态。 特点: java只能单…

如何发布Jar包到Maven中央仓库

https://www.iteblog.com/archives/1807.html转载于:https://www.cnblogs.com/longshiyVip/p/6858844.html

java previous_java – 在枚举类型上实现`next`和`previous`的最好方法是什么?

假设我有一个枚举:enum E {A, B, C;}如lucasmo by lucasmo所示,枚举值按照它们被初始化的顺序存储在静态数组中,您可以稍后用E.values()检索(克隆)此数组。现在假设我想实现E#getNext和E#getPrevious,以使所有下列表达式求值为tru…

什么是抽象类

抽象概念: 当我们在做子类共性功能抽取时,有些方法在父类中并没有具体的体现,这个时候就需要抽象类了! 在Java中,一个没有方法体的方法应该定义为抽象方法,而类中如果有抽象方法,该类必须定义为…

java 加密 sha_Java加密 消息摘要算法SHA实现详解

SHA是消息摘要算法的一种实现方式,前面已经总结过MD2\4\5的实现,接下来就为大家总结一下SHA的实现。SHA的jdk实现:private static void SHA_JDK(){try {MessageDigest digest MessageDigest.getInstance("SHA");//我们可以通过SHA…

monkeyrunner脚本的录制和回放

参考:http://www.cnblogs.com/android-host/p/5378996.html 需要条件: 1.android-sdk 2.monkey_recorder.py 3.monkey_playback.py 操作步骤: 1)新建monkey_recorder.py文件,复制以下代码: #!/usr/bin/env monkeyrunne…

什么是接口

概念: 接口是更加彻底的抽象,接口中全部是抽象方法。接口是不能直接创建对象的。从JDK8之后,接口中不再只是抽象方法,接口还可以有默认方法(也就是实例方法),和静态方法了,还包含了私…

php session作用,PHP中Session的作用

PHP session变量的作用是:存储用户的session信息,或者改变用户的session设置。Session变量储存了一个单一用户的信息,它可以被所有的页面使用。PHP Session变量当你在自己的计算机上运行一个应用程序时,你打开它,对他做…

Vuex核心知识(2.0)

Vuex核心知识(2.0) 转自:http://www.cnblogs.com/ghost-xyx/p/6380689.html Vuex 是一个专门为 Vue.js 应该程序开发的状态管理模式,它类似于 Redux 应用于 React 项目中,他们都是一种 Flux 架构。相比 Redux&#xff…

java带权连通图上最小权边,连通图最小生成树的算法及实现

连通图的最小生成树生成树定义:无向连通图G的极小连通子图,称为它的生成树。(n个顶点,n-1条边)考虑一下下面这个图上图是一个完全图,它的生成树不是唯一的,我们列出最特殊的两种情况上面2个图都是第一个完全图的生成树…

Android7.0,剪裁后提示“无法保存经过裁剪的图片”

今天在适配一下 7.0的拍照和选择照片,裁剪,发现拍照可以,选择图片也可以, 但是就是裁剪的时候不行,会弹出提示:无法保存经过裁剪的图片 后来才发现,在设置裁剪要保存的 intent.putExtra(MediaSt…

PHP垃圾回收机制理解

使用的是“引用计数”方式进行回收。简单地理解的话,就是每个分配的内存区域都有一个计数器,记录有多少个变量指针指向这片内存。当指向该片内存的指针数量为0,那么该片内存区域就可以被回收。 引用计数计数简单,强大,…

枚举的用法

概念: 为了间接的表示一些固定的值,Java就给提供了枚举,是指将变量的值一一列出来,变量的值只限于列举出来的值的范围内、 特点: 所有枚举类都是Enum的子类我们可以通过”枚举类名.枚举项名称”去访问指定的枚举项每一个枚举项其实…

在php中创建三个表格,创建新工作表PHPExcel

我正在尝试创建另一个工作表,一切正常.但我现在需要的是根据变量创建1.例如 :我有两个选项用于验证,一个用于结果.一切都由一个名为$resultado的布尔变量来约束.我在CakePHP中有我的组件function ExcelCargaMasivaComponent() {$this->xls new PHPExcel();$this…

java.lang.String类

复制下来的java.lang.String源码。在此基础上添加自己的注释,偷懒了,用来加深印象吧。英语不好,没有翻译,不理解的方法直接百度的。然后按照自己的理解描述。/** (#)String.java 1.205 09/02/26** Copyright 2006 Sun Microsys…

面向对象-多态

概念 多态是指同一行为,具有多个不同表现形式 多态是除封装、继承之后面向对象的第三大特征。 多态是出现在继承或者实现关系中的 使用多态有什么前提 要有继承或实现关系要有方法的重写要有父类引用指向子类对象 子类对象是可以赋值给父类类型的变量。例如Animal是…

php 区位码字符,php汉字如何转区位码

php汉字转区位码的方法:首先创建一个PHP示例文件;然后通过“sprintf("%02d%02d",ord($t1[0])-160,ord($t1[1])-160);”方法实现汉字转区位码即可。推荐:《PHP视频教程》PHP中实现汉字转区位码应用源码实例解析PHP里如何实现汉字转区…

ssh(struts,spring,hibernate)开发的初步集成01--依赖

一.概念 SSH 通常指的是 Struts2 做前端控制器,spring 管理各层的组件,hibernate 负责持久化层。 SSM 则指的是 SpringMVC 做前端控制器,Spring 管理各层的组件,MyBatis 负责持久化层。 二.构建流程 创建maven工程...在pom.xml文件…

频谱扩展 matlab,简单的直接扩展频谱通信系统仿真分析

随着通信技术的迅猛发展,扩展频谱通信技术的优点已经越来越明显并被接受,并在各个领域得到了广泛的应用。同时随着计算机技术和仿真技术的日益发展和应用,如何应用一些方便、友好的软件对通信系统进行直观的模型仿真,并进行仿真结…

内部类怎么用

内部类: 在一个类中定义一个类。 举例:在一个类A的内部定义一个类B,类B就被称为内部类 // 格式: class 外部类名{ 修饰符 class 内部类名{ } } class A{public class B {}}内部类的访问特点: 内部类可以直接访问外部类…