我正在尝试在我的@Dao接口中创建一个具有布尔参数isAsc的@query函数以确定顺序:
@query("SELECT * FROM Persons ORDER BY first_name (:isAsc ? ASC : DESC)")List<Person> getPersonsAlphabetically(boolean isAsc);
显然,这是不允许的.这附近有工作吗?
编辑:
使用两个查询(如下)似乎很奇怪,因为唯一的区别是ASC和DESC:
@query("SELECT * FROM Persons ORDER BY last_name ASC")List<Person> getPersonsSortByAscLastname();@query("SELECT * FROM Persons ORDER BY last_name DESC")List<Person> getPersonsSortByDescLastname();
解决方法:
使用CASE Expression for sqlite在Room DAO中实现此目的,
@query("SELECT * FROM Persons ORDER BY CASE WHEN :isAsc = 1 THEN first_name END ASC, CASE WHEN :isAsc = 0 THEN first_name END DESC")List<Person> getPersonsAlphabetically(boolean isAsc);
总结 以上是内存溢出为你收集整理的android-Room DAO按ASC或DESC排序全部内容,希望文章能够帮你解决android-Room DAO按ASC或DESC排序所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)