有没有一种方法可以通过 JPA 标准查询来订购类?想象以下领域对象:
abstract class Hobby { ... }
class Coding extends Hobby { ... }
class Gaming extends Hobby { ... }
使用常规 QL 我能够做到
from Hobby h order by h.class
但是当我在条件查询上应用相同的逻辑时,会发生运行时异常“未知属性”。
CriteriaQuery<Hobby> criteriaQuery = builder.createQuery(Hobby.class);
Root<Hobby> hobbyRoot = criteriaQuery.from(Hobby.class);
criteriaQuery.orderBy(builder.asc(hobbyRoot.get("class"));
List<Hobby> hobbies = entityManager.createQuery(criteriaQuery).getResultList();
使用的 JPA 实现:Hibernate-EntityManager v3.5.5-Final