我有一个示例用例,要求所有提供的条件都为真。条件由用户提供,因此直到运行时才知道。例如。
SELECT * FROM FOO WHERE [CONDITION 1] AND [CONDITION 2]...AND [CONDITION N]
有没有一种简单的方法可以在Android Room DAO @Query()中表达这一点?我目前正在使用2.1.0-beta01
答案 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);