如何在 SQLite android 中手动执行检查点?

How to manually perform checkpoint in SQLite android?

我正在尝试创建我的 sqlite 数据库的备份,我想先刷新数据库中 WAL 文件的内容。

这是我的 SQLiteOpenHelper:

public class MyDBHelper extends SQLiteOpenHelper {

private Context mContext;
private static MyDBHelper mInstance = null;

private MyDBHelper(final Context context, String databaseName) {
    super(new MYDB(context), databaseName, null, DATABASE_VERSION);
    this.mContext = context;
}

@Override
public void onCreate(SQLiteDatabase db) {

}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}
   public static MyDBHelper getInstance(Context context) {

    if (mInstance == null) {
        mInstance = new MyDBHelper(context, DATABASE_NAME);
    }
    return mInstance;
}

  private void closeDataBase(Context context) {
    getInstance(context).close();
}

}

现在,我的理解是检查点完成后,mydb.db-wal 文件应该是空的。对吗?

这是我目前尝试过的方法: 1.

    public Completable flushWalInDB() {
    return Completable.fromAction(new Action() {
        @Override
        public void run() throws Exception {
            getInstance(mContext).getReadableDatabase().rawQuery("pragma wal_checkpoint;", null);
        }
    });
}

这不会引发错误,但似乎什么也没做。在 运行 这之后,我实际检查了我的 mydb.db-wal 文件并且大小相同。我还检查了设备上的数据库,数据库中没有添加任何内容

经过一番挖掘,我发现了这个 [ 并尝试了这个:

2.

    public Completable flushWalInDB() {
    return Completable.fromAction(new Action() {
        @Override
        public void run() throws Exception {
            getInstance(mContext).getReadableDatabase().execSQL("pragma wal_checkpoint;");
        }
    });
}

当 运行 这会引发错误:

unknown error (code 0): Queries can be performed using SQLiteDatabase query or rawQuery methods only.

基于这个答案 [ ,我也尝试对数据库进行 VACUUM,但似乎没有任何反应。

 public Completable vacuumDb() {
    return Completable.fromAction(new Action() {
        @Override
        public void run() throws Exception {
            getInstance(mContext).getReadableDatabase().execSQL("VACUUM");
        }
    });
} 
}

在创建备份之前刷新数据库中的 WAL 文件的正确方法是什么?

谢谢。

PRAGMA wal_checkpoint(2) 确实将 WAL 中的所有数据复制到实际的数据库文件中,但它不会删除 -wal 文件,并且任何并发连接都可以在之后立即进行新的更改。

如果您想真正确定没有 WAL 干扰您的备份,运行 PRAGMA journal_mode = DELETE。 (之后您可以将其切换回来。)