使用房间动态订购

时间:2018-07-15 11:35:25

标签: android android-sqlite android-room

我想使用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);

1 个答案:

答案 0 :(得分:0)

好的,我找到了一个简单的答案。

我只是替换了语句- new SimpleSQLiteQuery("SELECT * FROM main_movie ORDER BY ? DESC", new Object[]{dbSortType})

对此:-

new SimpleSQLiteQuery("SELECT * FROM main_movie ORDER BY "+ dbSortType + " DESC"))