我想使用room创建一个动态查询,以便在一种情况下查询返回一种特定的订单类型,而在运行时,如果订单类型发生更改,则会创建一个新查询,并根据此类型对数据进行排序。 / p>
我正在使用Room返回一个DataSource.Factory对象。 我正在使用以下语句来处理我的查询:-
if(getSortOrderType().equals(context.getString(R.string.sortByPopular))) {
dbSortType = "popularity";
} else {
dbSortType = "vote_average";
}
movieLiveData =
new LivePagedListBuilder<>(MovieDatabase
.getMovieDbInstance(context)
.getMovieDao().getAllMovies(new
SimpleSQLiteQuery("SELECT * FROM main_movie ORDER BY ? DESC",
new Object[]{dbSortType})), config)
.setBoundaryCallback(movieModelBoundaryCallback)
.build();
但是,在运行时,我看到返回的数据是按已经设置的主键(即id)排序的,并不是根据我在上面的语句中构造的这种类型排序的。
如何使用该语句返回按所选排序类型排序的结果。
使用的Dao方法是:-
@RawQuery(observedEntities = MovieModel.class)
DataSource.Factory<Integer,MovieModel> getAllMovies(SupportSQLiteQuery query);
答案 0 :(得分:0)
好的,我找到了一个简单的答案。
我只是替换了语句-
new SimpleSQLiteQuery("SELECT * FROM main_movie ORDER BY ? DESC", new Object[]{dbSortType})
对此:-
new SimpleSQLiteQuery("SELECT * FROM main_movie ORDER BY "+ dbSortType + " DESC"))