JPA Predicate复杂查询排序

来源:互联网 发布:广州淘宝代运营诈骗 编辑:程序博客网 时间:2024/06/01 09:15

使用Predicate查询时,如果不分页,但是要排序,此时pageable无法使用。可以使用如下方法:

  1. Specification<UserModel> spec = new Specification<UserModel>() {  
  2.     public Predicate toPredicate(Root<UserModel> root,  
  3.             CriteriaQuery<?> query, CriteriaBuilder cb) {  
  4.         Predicate p1 = cb.like(root.get("name").as(String.class), "%"+um.getName()+"%");  
  5.         Predicate p2 = cb.equal(root.get("uuid").as(Integer.class), um.getUuid());  
  6.         Predicate p3 = cb.gt(root.get("age").as(Integer.class), um.getAge());  
  7.         //把Predicate应用到CriteriaQuery中去,因为还可以给CriteriaQuery添加其他的功能,比如排序、分组啥的  
  8.         query.where(cb.and(p3,cb.or(p1,p2)));  
  9.         //添加排序的功能  
  10.         query.orderBy(cb.desc(root.get("uuid").as(Integer.class)));  
  11.           
  12.         return query.getRestriction();  
  13.     }  
  14. };  
引用地址:http://blog.csdn.net/tfy1332/article/details/51245470


原创粉丝点击