ANDROID SQLITEOPENHELPER详解

来源:互联网 发布:什么软件充值油卡便宜 编辑:程序博客网 时间:2024/05/21 08:45

一、 SQLite介绍 
SQLite是android内置的一个很小的关系型数据库。 
SQLite的官网是http://www.sqlite.org/,可以去下载一些文档或相关信息。 
博客中有一篇有稍微详细一点的介绍,大家可以去看一下。 

二、 SQLiteOpenHelper的使用方法 
SQLiteOpenHelper是一个辅助类来管理数据库的创建和版本。 
可以通过继承这个类,实现它的一些方法来对数据库进行一些操作。 
所有继承了这个类的类都必须实现下面这样的一个构造方法: 
public DatabaseHelper(Context context, String name, CursorFactory factory, int version) 
第一个参数:Context类型,上下文对象。 
第二个参数:String类型,数据库的名称 
第三个参数:CursorFactory类型 
第四个参数:int类型,数据库版本 
下面是这个类的几个方法: 

方法名 返回类型 描述 备注 
getReadableDatabase() synchronized SQLiteDatabase 创建或打开一个数据库 可以通过这两个方法返回的SQLiteDatabase对象对数据库进行一系列的操作,如新建一个表,插入一条数据等 
getWritableDatabase() synchronized SQLiteDatabase 创建或打开一个可以读写的数据库
onCreate(SQLiteDatabase db) abstract void 第一次创建的时候调用
onOpen(SQLiteDatabase db) void 打开数据库
onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion) abstract void 升级数据库
close() synchronized void 关闭所有打开的数据库对象

SQLiteOpenHelper类:

复制代码
package android.sqlite;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import android.database.sqlite.SQLiteDatabase.CursorFactory;/** * SQLiteOpenHelper是一个辅助类,用来管理数据库的创建和版本他,它提供两个方面的功能 * 第一,getReadableDatabase()、getWritableDatabase()可以获得SQLiteDatabase对象,通过该对象可以对数据库进行操作 * 第二,提供了onCreate()、onUpgrade()两个回调函数,允许我们再创建和升级数据库时,进行自己的操作 */public class DatabaseHelper extends SQLiteOpenHelper {    private static final int VERSION = 1;    /**     * 在SQLiteOpenHelper的子类当中,必须有该构造函数     * @param context    上下文对象     * @param name        数据库名称     * @param factory     * @param version    当前数据库的版本,值必须是整数并且是递增的状态     */    public DatabaseHelper(Context context, String name, CursorFactory factory,            int version) {        //必须通过super调用父类当中的构造函数        super(context, name, factory, version);    }        public DatabaseHelper(Context context, String name, int version){        this(context,name,null,version);    }    public DatabaseHelper(Context context, String name){        this(context,name,VERSION);    }    //该函数是在第一次创建的时候执行,实际上是第一次得到SQLiteDatabase对象的时候才会调用这个方法    @Override    public void onCreate(SQLiteDatabase db) {        // TODO Auto-generated method stub        System.out.println("create a database");        //execSQL用于执行SQL语句        db.execSQL("create table user(id int,name varchar(20))");    }    @Override    public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {        // TODO Auto-generated method stub        System.out.println("upgrade a database");    }}
复制代码
0 0