如何在Android Room中运行多个AND查询?

时间:2019-05-12 07:29:11

标签: android android-room

我有一个示例用例,要求所有提供的条件都为真。条件由用户提供,因此直到运行时才知道。例如。

SELECT * FROM FOO WHERE [CONDITION 1] AND [CONDITION 2]...AND [CONDITION N]

有没有一种简单的方法可以在Android Room DAO @Query()中表达这一点?我目前正在使用2.1.0-beta01

1 个答案:

答案 0 :(得分:2)

您必须使用Raw Query

@Dao
 interface RawDao {
     @RawQuery
     User getFoo(SupportSQLiteQuery query);
 }

 SimpleSQLiteQuery query = new SimpleSQLiteQuery("SELECT * FROM Foo WHERE [CONDITION 1] AND [CONDITION 2]...AND [CONDITION N]");
 Foo foo = rawDao.getFoo(query);