14

我正在创建一个与数据库进行大量交互的应用程序(读取和写入操作)。

为了避免在每次请求时进行打开/关闭操作,我创建了一个SQLiteOpenHelper使用单例设计模式扩展的类。这样,我确信在整个应用程序生命周期(而不仅仅是活动SQLiteOpenHelper生命周期)中,只有一个实例,并且只有一个与数据库的连接。

我还阅读了一些关于 ContentProvider 的文章,但我不确定这是一个更好的方法。

因此,这是我的 Singleton 类(onCreateonUpgrade已删除)的主要逻辑:

public final class BaseSQLite extends SQLiteOpenHelper {

    private static BaseSQLite mInstance = null;

    private SQLiteDatabase db = null;

    public static BaseSQLite getInstance(Context context) {
        if (mInstance == null) {
            mInstance = new BaseSQLite(context.getApplicationContext(),
                    DBNAME, DBVERSION);
        }
        return mInstance;
    }

    private BaseSQLite(final Context context, final String name,
            final int version) {
        super(context, name, null, version);
        db = getWritableDatabase();
    }

    @Override
    public synchronized void close() {
        if (mInstance != null)
            db.close();
    }

    public Cursor getAllData() {
        String buildSQL = "SELECT * FROM myTable";

        return db.rawQuery(buildSQL, null);
    }

}

所以,为了访问我的数据库,我做了这个:

BaseSQLite baseSQLite = BaseSQLite.getInstance(context);
baseSQLite.getAllData();

它现在完美运行。但我的问题是关于close()方法。我真的不知道什么时候打电话。实际上,我的数据库实例对于我的应用程序的每个 Activies 都是相同的,所以我认为调用close()onPause() 方法是个坏主意,因为该实例可能(并且经常会发生)onStart()在下一个活动。此外,我无法检测到end我的应用程序,即当屏幕上不再可见任何活动时。

有人可以就这个问题给我一些帮助吗?当数据库链接到一个活动时,我找到了一些答案,但没有为我的案例提供真正的提示。

4

1 回答 1

1

每当您完成对数据库的写入后,您都应该调用 close 。例如,当您插入数据时,您将与数据库建立一个打开的连接,完成后应该关闭该连接。

读书不一样。当您在手机上创建 SQLite 数据库时,数据是持久的。数据库存在,您创建的处理程序提供了访问该信息的便捷方式。读取数据库通常通过获取数据库的可读实例并使用 aCursor来提取值来进行。在这种情况下,您在完成后关闭游标,而不是数据库本身。

您是对的,您不应该在单独活动的生命周期方法中关闭数据库连接。相反,如上所述,当您完成执行该事务时,请关闭写入数据库的处理程序方法中的数据库连接。

于 2013-07-24T12:57:46.887 回答