Android SQLiteOpenHelper使用和源码详解

本文详细探讨了Android中SQLiteOpenHelper的使用,包括如何构建自定义的SQLiteOpenHelper,以及其源码分析。重点在于理解onCreate和onUpgrade方法的调用时机,并非在构造函数中,而是在调用getWritableDatabase或getReadableDatabase时根据数据库版本变化触发。源码注释揭示了只有版本号不一致时,这些函数才会执行,否则仅打开数据库文件句柄。
摘要由CSDN通过智能技术生成

SQLiteOpenHelper

在讲解闹钟数据库之前,需要先来分析一下SQLiteOpenHelper的源码,从而了解SQLite数据库的使用.

使用方法

大家在使用SQLiteOpenHelper的时候,一般习惯使用如下代码构建一个自定义的SQLiteOpenHelper:

public class TestDBHelper extends SQLiteOpenHelper {
   
    public static final int DATABASE_VERSION = 1;
    public static final String DATABASE_NAME = "test.db";

    private static final String SQL_CREATE_TEST_TABLE = "CREATE TABLE " + TestTable.TABLE_NAME +
            " (" +
            TestTable._ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
            TestTable.COLUMN_NAME_TEST_NAME + " TEXT, " +
            TestTable.COLUMN_NAME_TEST_TIME_YEAR + " INTEGER, " +
            TestTable.COLUMN_NAME_TEST_TIME_MONTH + " INTEGER, " +
            TestTable.COLUMN_NAME_TEST_TIME_DAY + " INTEGER, " +
            " )";

    private static final String SQL_DELETE_TEST_TABLE = "DROP TABLE IF EXISTS " +
            TestTable.TABLE_NAME;

    private static TestDBHelper mInstance;
    private SQLiteDatabase rdb;
    private SQLiteDatabase wdb;

    private TestDBHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
        wdb = mInstance.getWritableDatabase();
        rdb = mInstance.getReadableDatabase();
    }

    public TestDBHelper getInstance(Context context) {
        if (mInstance == null) {
            synchronized (TestDBHelper.class) {
                if (mInstance == null) {
                    mInstance = new TestDBHelper(context);
                }
            }
        }
        return mInstance;
    }

    @Override
    public void <
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值