Android Room Dao:OrderBy CASE不起作用。
创始人
2024-08-15 10:00:54
0

在Android Room中使用OrderBy CASE语句时,可能会遇到无法正常工作的问题。为了解决这个问题,可以尝试以下解决方法:

  1. 使用@Query注解手动编写自定义的SQL查询语句,而不是使用Room的自动生成查询。这样可以更灵活地控制查询逻辑。例如:
@Dao
public interface UserDao {
    @Query("SELECT * FROM User ORDER BY CASE WHEN :sort = 'name' THEN name END")
    List getUsersSortedByName(String sort);
}
  1. 使用Room的SortingMapping类,它可以在查询结果中对结果进行排序。首先,创建一个自定义的SortingMapping类来实现排序逻辑:
public class UserSortMapping {
    public String sortField;
    public String name;

    public UserSortMapping(String sortField, String name) {
        this.sortField = sortField;
        this.name = name;
    }
}

然后,在查询方法中使用SortingMapping类来进行排序:

@Dao
public interface UserDao {
    @Query("SELECT name AS name, name AS sortField FROM User ORDER BY :sortField")
    List getUsersSortedByName(String sort);
}

这样,就可以根据传入的排序字段进行排序。

这些解决方法可以帮助您解决Android Room Dao中使用OrderBy CASE不起作用的问题。

相关内容

热门资讯

揭露透视!wepoker免费脚... 揭露透视!wepoker免费脚本咨询,wepoker可以开透视吗,原来是真的有辅助技巧(哔哩哔哩)1...
了解透视!wepoker透视脚... 了解透视!wepoker透视脚本免费下载pc,wepoker的辅助器,都是是真的有辅助教程(哔哩哔哩...
必备透视!wepoker透视脚... 必备透视!wepoker透视脚本,wepoker透视脚本是什么,好像真的有辅助方法(哔哩哔哩)一、e...
揭幕透视!购买wepoker模... 揭幕透视!购买wepoker模拟器,wepoker破解器,原来真的有辅助技巧(哔哩哔哩)1、辅助器安...
开挂透视!德普之星有透视辅助吗... 开挂透视!德普之星有透视辅助吗,德扑圈透视,切实是有辅助工具(哔哩哔哩)1、完成有辅助插件,帮助玩家...
分享透视!如何判断wpk辅助软... 分享透视!如何判断wpk辅助软件的真假,wpk安卓下载辅助,竟然是有辅助神器(哔哩哔哩)1、用户打开...
开挂透视!wepoker插件程... 开挂透视!wepoker插件程序激活码,黑侠破解wepoker,一贯是有辅助软件(哔哩哔哩)1、许多...
专业透视!wpk插件,如何判断... 专业透视!wpk插件,如何判断wpk辅助软件的真假,本来存在有辅助软件(哔哩哔哩)1、免费脚本咨询教...
关于透视!aapoker辅助器... 关于透视!aapoker辅助器是真的吗,aapoker破解侠是真的吗,都是一直总是有辅助软件(哔哩哔...
曝光透视!德普辅助软件,德普之... 曝光透视!德普辅助软件,德普之星怎么设置埋牌,好像有辅助技巧(哔哩哔哩)1、下载好正确养号方法之后点...