数据持久化技术
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对象中取出数据:可以使用指针+循环+读取的方式一个一个读取出来