小编MMT*_*MMT的帖子

在jpa中按顺序选择大小写

SELECT * FROM orderTable order by 
CASE priority when 'CRITICAL' THEN 1 
   when 'HIGH' then 2 
   when 'MEDIUM' then 3 
   when 'LOW' then 4 
   when 'NOT_ASSIGNED' then 5 
end ASC ,
CreatedAt ASC;
Run Code Online (Sandbox Code Playgroud)

这是我的mysql查询及其工作方式。数据库列priority是字符串类型,并且该字符串具有以下优先级

我想要用jpa语言之类的语言

CriteriaBuilder cb = em.getCriteriaBuilder();       
CriteriaQuery<T> cq = cb.createQuery(entityClass);
Root<T> root = cq.from(entityClass);
cb.selectCase().when(cb.equal(root.get("priority"), "CRITICAL"), 1)
    .when(cb.equal(root.get("priority"), "HIGH"), 2)
    .when(cb.equal(root.get("priority"), "MEDIUM"), 3)
    .when(cb.equal(root.get("priority"), "LOW"), 4)
    .when(cb.equal(root.get("priority"), "NOT_ASSIGNED"), 5).;
Order temp2 = cb.desc(root.get("priority"));
cq = cq.orderBy(temp2);
Run Code Online (Sandbox Code Playgroud)

这是行不通的,它只按字符串优先级返回结果。选择的情况下不适用于标准构建查询。

java mysql hibernate jpa

2
推荐指数
1
解决办法
2216
查看次数

标签 统计

hibernate ×1

java ×1

jpa ×1

mysql ×1