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();
我需要按三个不同的字符串对我的数据库响应进行排序。
字段只能采用这四个值 "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();