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

本文详细介绍在Android中如何使用SQLiteOpenHelper类创建数据库。从自定义子类到实现构造方法及onCreate()方法,再到数据库的创建与操作,文章一步步引导读者掌握数据库创建的全过程。

各位看官们大家好,上一回中咱们说的是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中数据存储之数据库的例子咱们就介绍到这里,欲知后面还有什么例子,且听下回分解!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

talk_8

真诚赞赏,手有余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值