1、SQLiteOpenHelper是什么?
A helper class to manage database creation and version management.
一个数据库创建和版本管理的帮助类。
2、SQLiteOpenHelper作用
SQLiteOpenHelper既然是帮助类,并且是管理数据库的创建和版本,那么为什么类名包含"Open"这个单词呢?为什么不叫SQLiteManageHelper,或者更准确的,SQLiteCreationAndUpgradeHelper呢?
一个简单的操作数据库的流程是这样的:打开数据库->sql操作数据库->关闭数据库。而打开数据库,涉及很多细节:
(1)这个数据库是否存在?如果不存在,就要考虑先创建数据库,创建各种数据表。
(2)这个数据库是否需要升级,比如目前的数据库结构已经不能满足我们的需求了,我们需要更改数据库的结构,这个时候就要先升级数据库,更新数据库的结构。
(3)这个数据库是否之前已经打开?一般来说,我们操作数据库结束之后,需要关闭数据库,以节约资源。但是如果我们之前打开的数据库还要继续使用,这时候再执行打开操作时,直接返回这个数据库就行了。
SQLiteOpenHelper把打开数据库的一系列需要考虑到的细节逻辑都封装了起来,这也是为什么包含了Open这个单词的原因了。因为SQLiteOpenHelper的主要工作就是把打开数据库的逻辑帮我们实现了。
3、SQLiteOpenHelper回调方法
(1) onCreate: 创建数据库时会调用,我们需要