美文网首页
数据持久化技术

数据持久化技术

作者: 努力科研的小树蛙 | 来源:发表于2016-07-02 14:36 被阅读0次

    1 android三种数据持久化存储技术

    (1)文件存储:简单,不做格式化处理,适用于文本文件、二进制文件

    (2)SharedPrefence存储:适用于一些键值对

    (3)数据库存储:适用于更复杂的关系型数据

    2 文件存储

    (1)所有的文件默认存储到/data/data/<package name>/files/目录下

    (2)使用Context类中的openFileOutput()方法

    openFileOutput(文件名,文件操作模式)

    文件操作模式:

    MODE_PRIVATE:覆盖原有的文档

    MODE_APPEND:在原有文档的基础上追加

    (3)使用过程:将数据从应用程序存入文件中【实现于onDestory中,这样保证数据在程序退出前能够得到保存】

    a 使用openFileOutput返回一个FileOutputStream对象

    b 使用java将数据写入到这个对象中去

    将数据从文件中读取进应用程序: 使用的是Context类中的openFileInput方法【实现于oncreate,这样保证在程序一创建的时候就能够读取数据】

    a openFileInput(文件名)

    b 返回一个FileInputStream对象,得到对象后再通过java流的方式将数据读取出来

    3 SharedPreferences存储

    将数据存储到SharedPreferences中:SharedPreference使用的是xml格式来对数据进行管理

    a 获取SharedPreferences对象

    b 调用SharedPreferences对象的edit()方法获取一个SharedPreference.Editor对象

    c 向SharedPreference.Editor对象中添加数据

    d 调用commit()方法将添加的数据提交,从而完成数据存储操作

    将数据从SharedPreferences中读取出来

    a 获取sharedPreferences对象

    b 调用相应的getString()、getInt()、getBoolean()等方法获取数据

    SQLite数据库存储

    1 SQLiteOpenHelper帮助类:进行数据库的创建和升级

    2 两个抽象方法

    onCreate():在此方法中实现创建数据库

    onUpgrade():在此方法中实现升级数据库

    3 两个实例方法:实现创建或者打开数据库,并返回一个可以对数据库进行读写操作的对象

    getReadableDatabase():

    getWritabledatabase()

    4 构造方法

    MyDatabaseHelper dbHelper=new MyDatabaseHelper(this,数据库名,null,版本号);

    5 使用方法

    a 使用构造方法构建SQLiteOpenHelper实例

    b 对实例使用两个实例方法创建数据库,创建完成后的数据库位于/data/data/<package name>/databases/目录下

    c  使用重写的onCreate()方法处理一些创建表的逻辑:可以将建表等语句写成string,然后使用execSQL()方法的去执行

    a、b两部均在MainActivity.java类中实现,第三步在SQLiteOpenHelper类中实现。

    6 添加数据

    a 使用ContentValues对象封装数据

    ContentValues values=new ContentValues();

    values.put(数据项,值);

    values.out()

    ......

    b 对数据库使用insert将ContentValues对象传入

    db.insert(表名,null,ContentValues)

    7 修改数据

    a 使用ContentValues对象封装数据

    b 对数据库使用upgrade将ContentValues对象传入

    db.update(表名,ContentValues,约束更新某一行或某几行,约束更行某一行或某几行)

    8 删除数据

    db.delete("表名",约束删除的行,约束删除的行)

    9 查询数据

    a 使用query()方法获取一个Cursor对象,所有想要的数据都在这个对象里

    query(查询的表名,查询的列名,指定的约束条件,为占位符提供值,group by,组织后进一步约束,查询结果排序方式)

    b 从Cursor对象中取出数据:可以使用指针+循环+读取的方式一个一个读取出来

    相关文章

      网友评论

          本文标题:数据持久化技术

          本文链接:https://www.haomeiwen.com/subject/pusqjttx.html