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

时间:2018-07-26 09:13:41

标签: android sqlite mobile checkpoint

我正在尝试创建我的sqlite数据库的备份,我想先刷新db中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文件,并具有相同的大小。我还检查了设备上的数据库,但数据库中未添加任何内容

经过一番挖掘,我发现了这个 [https://stackoverflow.com/a/30278485/2610933][1] 并尝试了这个:

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.

根据这个答案[https://stackoverflow.com/a/19574341/2610933][1],我也尝试过抽空数据库,但似乎什么也没发生。

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

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

谢谢。

1 个答案:

答案 0 :(得分:1)

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

如果您要确定没有WAL干扰备份,请运行PRAGMA journal_mode = DELETE。 (您可以稍后将其切换回。)