本文章转载于搜狗测试
一.存储方式概述
在Android系统中,主要有五种数据存储模式。
1. Sharedferences:Sharedferences是一种轻型的数据存储方式,本质上是基于XML文件存储key-value键值对数据。通常用来存储一些简单的配置信息。
2. SQLite:SQLite是一个轻量级的数据库,存储结构化的数据,支持基本SQL语法,是常被采用的一种数据存储方式。Android系统为SQLite提供了一个名为SQLiteDatabase的类并封装了一些CRUD操作的API。后文将做一个简单的介绍。
3. 文件:即使用文件进行数据存储。
4.ContentProvider:ContentProvider为存储和获取数据提供统一的接口,表现出来的特点是可以在不同的应用程序之间共享数据。
5.Network:即使用基于网络的服务存取数据。
二.SharedPreferences
SharedPreferences的使用简单方便,但是SharedPreferences只能保存简单类型的数据,例如,String、int、Boolean等类型的值。一般会将复杂类型的数据转换成Base64编码,然后将转换后的数据以字符串的形式保存在XML文件中,再用SharedPreferences保存。
使用SharedPreferences保存key-value数值对的步骤如下:
(1)使用Activity类的getSharedPreferences方法获得SharedPreferences对象。如
则表示获取SharePreferences对象为mSharedPreferences。后者是一个全局的定义的变量。
(2)使用SharedPreferences提供的函数接口edit()获得SharedPreferences.Editor对象。
(3) 通过SharedPreferences.Editor接口的putX方法保存key-value对。其中X表示不同的数据类型。例如:字符串类型的value需要用putString方法,布尔型则需要使用putBoolean方法。
(4)通过SharedPreferences.Editor接口的commit方法保存key-value对。commit方法相当于数据库中的提交操作
如这三行代码则将布尔型值LastRunSuccess的值设置为false,并将其提交到SharedPreferences中。
而从SharePreferences读取数据的过程,则采用getX的方式。如对于上述代码如需读取LastRunSuccess的值,则可采用以下这一行代码实现。
则可得到LastRunSuccess的值,其中getBoolean中第二个参数true表示默认值。
Sharedpreference的存储路径位于“/data/data/程序包名/shared_prefs”下,打开目录可见若干xml格式的文件。打开xml文件可见若干键值对。其中包含一行数据
则是上述代码运行过程中存储到本地的数据。
三.Sqlite
SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,目前已经在很多嵌入式产品中使用了它。SQLite占用资源非常低,在嵌入式设备中可能只需要几百K的内存就够了。
Sqlite有NULL,INTEGER,REAL,TEXT,BOB五种常用数据类型。Android提供了创建和是用SQLite数据库的API。其常用方法有
1)openOrCreateDatabase(String path,SQLiteDatabase.CursorFactory factory)
用于打开或者创建一个数据库。如果存在对应数据库,则会打开。如果不存在,则会创建一个数据库,创建成功则返回一个SQLiteDatabase对象,否则抛出异常FileNotFoundException。
2)execSQL(String sql)用于执行一条sql语句。
3)insert(String table,StringnullColumnHack,ContentValues values),用于插入一条记录;delete(String table,StringwhereClause,String[] whereArgs),删除一条记录;update(String table,ContentValues values,StringwhereClause,String[] whereArgs),修改一条记录;query(String table,String[] columns,
Stringselection,String[]selectionArgs,String groupBy,Stringhaving,String
orderBy),查询一条记录。
4) close() 即为关闭数据库。