且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

删除数据库后未调用ContentProvider onCreate

更新时间:2022-11-24 22:49:47

我找到了解决方案,

首先,我引用了在还原后在自定义ContentProvider中刷新/重新加载数据库引用,但对答案不满意,因为它只是用于关闭数据库.

First of all I referred Refresh/Reload database reference in custom ContentProvider after restore but not satisfied with answer because its just for closing database.

所以我创建了如下答案:

So I have created my answer as below:

DBHelper.java

/**
 * Delete database
 */
public static void reCreateDatabase(Context mContext) {
    ContentResolver resolver = mContext.getContentResolver();
    ContentProviderClient client = resolver.acquireContentProviderClient(KOOPSContentProvider.AUTHORITY);

    assert client != null;
    KOOPSContentProvider provider = (KOOPSContentProvider) client.getLocalContentProvider();

    assert provider != null;
    provider.resetDatabase();

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N)
        client.close();
    else
        client.release();

    LOGD("Database Deleted...");
}

public void removeDatabase(Context mContext) {
    mContext.deleteDatabase(DATABASE_NAME);
    LOGD("Database Deleted...");
}

KOOPSContentProvider.java

public void resetDatabase() {
    if(dbHelper != null) {
        dbHelper.removeDatabase(getContext());
        dbHelper = new DbHelper(getContext());
    } else {
        LOGD("Database NULL");
    }
}

用途为:

DbHelper.reCreateDatabase(mContext);

谢谢:):)