第6章 数据存储全方案,详解持久化技术

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第6章 数据存储全方案,详解持久化技术相关的知识,希望对你有一定的参考价值。

第6章 数据存储全方案,详解持久化技术

所有的App都可以说是与数据打交道的,离开数据它们什么都不是.那么平时我们怎么存储一些关键的数据呢?

1 持久化技术简介

数据持久化就是指将那些内存中的瞬时数据保存到存储设备中,保证即使在手机或电脑关机的情况下,这些数据仍然不会丢失。保存在内存中的数据是处于瞬时状态的,而保存在存储设备中的数据是处于持久状态的,持久化技术则是提供了一种机制可以让数据在瞬时状态和持久状态之间进行转换

android系统中主要提供了三种方式用于简单地实现数据持久化功能,即文件存储、SharedPreference存储以及数据库存储。当然,除了这三种方式之外,你还可以将数据保存在手机的SD卡中,不过使用文件、SharedPreference或数据库来保存数据会相对更简单一些,而且比起将数据保存在SD卡中会更加的安全。

2 文件存储

????文件存储是Android中最基本的一种数据存储方式,它不对存储的内容进行任何的格式化处理,所有数据都是原封不动地保存到文件当中的,因而它比较适合用于存储一些简单的文本数据或二进制数据.

2.1 将数据存储到文件中

Context类中提供了一个openFileOutput ()方法,可以用于将数据存储到指定的文件中。

openFileOutput ()方法返回的是一个FileOutputStream对象,得到了这个对象之后就可以使用Java流的方式将数据写入到文件中了.

技术分享

BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(openFileOutput("data", Context.MODE_PRIVATE)));

writer.write(data);

?

那么我们来创建一个实际的例子,使用openFileOutput()来进行数据存储.

S1:在activity_main.xml中创建一个EditText控件

技术分享

S2:在MainActivity.java中运用openFileOutput()方法保存数据

技术分享

S3:运行项目并查看

技术分享

技术分享

?

2.2 从文件中读取数据

????将数据存储到文件中,Context类中还提供了一个openFileInput()方法,用于从文件中读取数据.

????例子程序:

????技术分享

3 SharedPreferences存储

不同于文件储存方式,SharedPreferences采用键值对的方式进行存储.也就是说,但保存或获取一个数据,必须同时提供这个数据的Key值.

并且,SharedPreferences可以保存不同类类型的数据,如果保存的是整数,那么取出的就是整数;如果保存的是String字符串,那么取出的也是字符串.

具体的用法下面会详述.

3.1 将数据存储到SharedPreferences中

要使用SharedPreferences保存数据就必须在程序中获得SharedPreferences.这个对象有三种方式获取:

1)Context类中的的getSharedPreferences()方法:这个参数会传入两个参数,SharedPreferences的文件名和操作模式.如果传入的文件名不存在,则会在/data/data/<packagename>/shared_prefs/目录下;操作模式有两种,MODE_PRIVATE和MODE_MULTI_PROCESS.MODE_PRIVATE指的是只有当前程序才能对该文件进行读取,MODE_MULTI_PROCESS一般用于多个进程对这个文件进行访问.(MULTI 许多)

2)Activity类中的getPreferences()方法:与上面这个方法比,这个方法只接受一个参数,就是操作模式的参数.文件名默认为当前活动的类名.

3)PreferenceManager类中的getDefaultSharedPreferences()方法:这是一个静态方法,它接受一个Context参数.并默认使用当前活动的包名作为前缀来命名SharedPreferences文件

?

得到SharedPreferences对象后,就可以向SharedPreferences文件进行数据存储了.存储的步骤分为三步:

S1:调用SharedPreferences对象的edit()方法来获取一个SharedPrefences.Editor对象

S2:用SharedPrefences.Editor对象的putXxx()方法,向Editor对象中添加数据

技术分享

S3:调用commit()方法,提交并存储数据

?

例子程序:

activity_main.xml

技术分享

MainActivity.java

技术分享

?

我们看看实际效果:

技术分享

技术分享

实际上他是以XML文件进行存储的

3.2 从SharedPreferences中读取数据

直接上代码说明使用方法:

S1:在activity_main.xml文件中新建一个Button

技术分享

S2:在MainActivity.java中书写这个Button的点击事件

技术分享

3.3 实现记住密码功能

S1:实现一个lauout:Login.xml

????技术分享

S2:创建LoginActivity.java

技术分享

S3:在AndroidMainfest.xml中注册Login.xml和activity_main.xml文件

技术分享

S4:运行程序

4 SQLite数据库存储

Android OS中行有个DB---SQLite数据库.Android中的SQLite数据库到底是如何使用的呢?

4.1 创建数据库

Android为了让我们能够更加方便地管理数据库,专门提供了一个SQLiteOpenHelper帮助类,借助这个类就可以非常简单地对数据库进行创建升级;

1) SQLiteOpenHelper是一个抽象类.如果我们想要使用它的话,就需要创建一个自己的帮助类去继承它

2) SQLiteOpenHelper中有两个抽象方法,分别是onCreate()和onUpgrade(),我们必须在自己的帮助类里面重写这两个方法,然后分别在这两个方法中去实现创建、升级数据库的逻辑.

3) SQLiteOpenHelper中还有两个非常重要的实例方法,getReadableDatabase()和getWritableDatabase()。这两个方法都可以创建或打开一个现有的数据库(如果数据库已存在则直接打开,否则创建一个新的数据库),并返回一个可对数据库进行读写操作的对象

4) SQLiteOpenHelper中有两个构造方法可供重写,一般使用参数少一点的那个构造方法即可。这个构造方法中接收四个参数,第一个参数是Context,这个没什么好说的,必须要有它才能对数据库进行操作。第二个参数是数据库名,创建数据库时使用的就是这里指定的名称。第三个参数允许我们在查询数据的时候返回一个自定义的Cursor,一般都是传入null。第四个参数表示当前数据库的版本号,可用于对数据库进行升级操作。构建出SQLiteOpenHelper的实例之后,再调用它的getReadableDatabase()或getWritableDatabase()方法就能够创建数据库了,数据库文件会存放在/data/data/<package name>/databases/目录下。此时,重写的onCreate()方法也会得到执行,所以通常会在这里去处理一些创建表的逻辑。

?

实例:

S1:创建继承SQLiteOpenHelper的实现类MyDatabaseHelper,并重写onCreate()方法

S2:在MainActivity.java中调用getWritableDatabase()方法

技术分享

技术分享

验证下数据库是否生成:

技术分享

4.2 升级数据库

考虑一个情况,现在我们的数据库中已经有一张记录各个书的详细信息表Book,现在我们需要添加一张用户记录书籍分类的表Category,那么该怎么做呢?

创建Category表的语句为:

create table Category (

id integer primary key autoincrement,

category_name text,

category_code integer)

这个需求是不是直接在MyDatabaseHelper.java中加入上述Create语句,并在onCreate()方法中调用呢?

技术分享

当然不是!

???? 其实没有创建成功的原因不难思考,因为此时BookStore.db数据库已经存在了,之后不管我们怎样点击Create database按钮,MyDatabaseHelper中的onCreate()方法都不会再次执行,因此新添加的表也就无法得到创建了。

???? 解决方案就是在上面的基础上修改onUpgrade()方法:

技术分享

????注意,这个时候在MainActivity.java中,调用MyDatabaseHelper的构造方法时输入的第四个参数要有所不同:

????技术分享

?

4.3 添加数据

见面介绍的是创建和升级数据库

4.4 更新数据

?

4.5 删除数据

?

4.6 查询数据

?

4.7 使用SQL操作数据库

?

5 SQLite数据库的最佳实践

?

5.1 使用事务

?

5.2 升级数据库的最佳写法

?

6 小结与点评

?

?

以上是关于第6章 数据存储全方案,详解持久化技术的主要内容,如果未能解决你的问题,请参考以下文章

第一行代码 6.4 数据存储全方案-详解持久化数据- 数据库

第一行代码 Android 第二版到货啦

《第一行代码Android(第3版)》— Android 书籍

第一行代码 学习

第6章 初识MyBatis

Android第一行代码--详解持久化技术