如何使用房间持久性库删除特定表上的所有条目? 我需要删除表,但我无法找到如何做到这一点的任何信息。

仅当数据库正在迁移或加载所有条目并删除它们:)


当前回答

当使用RxJava在后台执行这个任务时,我有删除所有方法的问题。这是我最终解决问题的方法:

@Dao
interface UserDao {
    @Query("DELETE FROM User")
    fun deleteAll()
}

and

fun deleteAllUsers() {
    return Maybe.fromAction(userDao::deleteAll)
        .subscribeOn(Schedulers.io())
        .observeOn(AndroidSchedulers.mainThread())
        .subscribe ({
            d("database rows cleared: $it")
        }, {
            e(it)
        }).addTo(compositeDisposable)
}

其他回答

从1.1.0房间开始,你可以使用clearAllTables():

删除作为entities()注册到此数据库的所有表中的所有行。

如果想要从Room中的表中删除一个条目,只需调用这个函数,

@Dao
public interface myDao{
    @Delete
    void delete(MyModel model);
}

更新:如果你想删除完整的表,调用下面的函数,

  @Query("DELETE FROM MyModel")
  void delete();

注意:这里MyModel是一个表名。

当使用RxJava在后台执行这个任务时,我有删除所有方法的问题。这是我最终解决问题的方法:

@Dao
interface UserDao {
    @Query("DELETE FROM User")
    fun deleteAll()
}

and

fun deleteAllUsers() {
    return Maybe.fromAction(userDao::deleteAll)
        .subscribeOn(Schedulers.io())
        .observeOn(AndroidSchedulers.mainThread())
        .subscribe ({
            d("database rows cleared: $it")
        }, {
            e(it)
        }).addTo(compositeDisposable)
}

使用clearAllTables()与RXJava,如下所示,以避免java.lang.IllegalStateException:不能访问主线程上的数据库,因为它可能会锁定UI很长一段时间。

Completable.fromAction(new Action() {
        @Override
        public void run() throws Exception {
            getRoomDatabase().clearAllTables();
        }
    }).subscribeOn(getSchedulerProvider().io())
            .observeOn(getSchedulerProvider().ui())
            .subscribe(new Action() {
                @Override
                public void run() throws Exception {
                    Log.d(TAG, "--- clearAllTables(): run() ---");
                    getInteractor().setUserAsLoggedOut();
                    getMvpView().openLoginActivity();
                }
            }, new Consumer<Throwable>() {
                @Override
                public void accept(Throwable throwable) throws Exception {
                    Log.d(TAG, "--- clearAllTables(): accept(Throwable throwable) ----");
                    Log.d(TAG, "throwable.getMessage(): "+throwable.getMessage());


                }
            });

您可以创建一个DAO方法来做到这一点。

@Dao 
interface MyDao {
    @Query("DELETE FROM myTableName")
    public void nukeTable();
}