QueryDsl orderBy 特定字符串值

QueryDsl orderBy specific string values

我需要按三个不同的字符串对我的数据库响应进行排序。
字段只能采用这四个值 "A", "B", "C", null
有没有办法在使用 QueryDsl 从数据库 中检索数据时 以自定义顺序 对数据进行排序?

customOrder = ["B", "A", "C"]

解决方案是使用 CASE 为案例分配编号,并使用 ASC/DESC 对这些编号进行排序。

SQL中的解决方案:

SELECT *
FROM table
ORDER BY CASE 
   WHEN field = 'B' THEN 1,
   WHEN field = 'A' THEN 2,
   WHEN field = 'C' THEN 3
   ELSE 4
   END

解决方案:

private OrderSpecifier<Integer> provideStatusOrder() {
        NumberExpression<Integer> cases = new CaseBuilder()
                                                  .when(field.eq("B"))
                                                  .then(1)
                                                  .when(field.eq("C"))
                                                  .then(2)
                                                  .when(field.eq("A"))
                                                  .then(3)
                                                  .otherwise(4);
        return new OrderSpecifier<>(Order.ASC, cases);
}

用法:

return query.orderBy(provideStatusOrder())
            .fetch();