一起Talk Android吧(第二百二十六回:Android中的数据存储之数据库一)

各位看官们大家好,上一回中咱们说的是Android中数据存储之数据库的例子,这一回咱们继续说该例子。闲话休提,言归正转。让我们一起Talk Android吧!

看官们,我们在上一章回中主要是对数据库这种数据存储方式进行了概述性介绍,这一回中我们介绍如何创建数据库。

Android提供了一个叫作SQLite的数据库,并且提供了很多编程接口供我们使用,我们创建数据库时使用的是SQLiteOpenHelper类提供的接口,下面我们将通过代码结合文字的形式来介绍如何创建数据库,下面是具体的操作步骤请大家参考:

  • 1.自定义一个SQLiteOpenHelper类的子类,并且在类中重写构造方法和onCreate()方法来实现对数据库的操作;
 // 创建SQLiteOpenHelper的子类并且重写构造方法和onCreeate()等回调方法
class SchloolDB extends SQLiteOpenHelper {
    public SchloolDB(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    public SchloolDB(Context context, String name, SQLiteDatabase.CursorFactory factory, int version, DatabaseErrorHandler errorHandler) {
        super(context, name, factory, version, errorHandler);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        Log.i(TAG, "onCreate of DB");
        db.execSQL(CREATE_STUDENT);
    }

    @Override
    public void onOpen(SQLiteDatabase db) {
        super.onOpen(db);
        Log.i(TAG, "onOpen of DB");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        Log.i(TAG, "onUpgrade of DB");
    }
}
  • 2.创建步骤1中子类的对象,创建时在构造函数中传入数据库的名字和版本号;
  • 3.使用步骤2中创建的对象来创建或者打开数据库,使用的方法为getWritableDatabase()或者getReadableDatabase()方法;
public void CreateDB(Context context) {
    //创建自定义子类的对象,通过该对象创建具体的数据库
    Log.i(TAG, "CreateDB: Create and open DB");
    mSchloolDB = new SchloolDB(context,DB_NAME,null,DBVersion);
    mDatabase = mSchloolDB.getWritableDatabase();
}
  • 4.关闭数据库;使用步骤2中创建的对象来关闭数据库;使用的方法是close;
protected void onDestroy() {
    super.onDestroy();
    if(mSchloolDB != null && mDatabase != null) {
        Log.i(TAG, "onDestroy: Close DB");
        mDatabase.close();
        mDatabase = null;
        mSchloolDB = null;
    }
}

各位看官,关于Android中数据存储之数据库的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章