android-Room DAO按ASC或DESC排序

android-Room DAO按ASC或DESC排序,第1张

概述我正在尝试在我的@Dao接口中创建一个具有布尔参数isAsc的@Query函数以确定顺序:@Query("SELECT*FROMPersonsORDERBYfirst_name(:isAsc?ASC:DESC)")List<Person>getPersonsAlphabetically(booleanisAsc);显然,这是不允许的.这附近有工作吗?编辑:使用两个查询(如下)

我正在尝试在我的@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排序所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1081726.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存