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

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

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

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

最佳答案
您必须使用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);

相关文章

Android 如何解决dialog弹出时无法捕捉Activity的back事件 在...
Android实现自定义带文字和图片的Button 在Android开发中经常...
Android 关于长按back键退出应用程序的实现最近在做一个Andr...
android自带的时间选择器只能精确到分,但是对于某些应用要求...