使用SpringDataJPA如何实现多条件的分页查询-创新互联

创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、成都网站建设、下城网络推广、小程序制作、下城网络营销、下城企业策划、下城品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们大的嘉奖;创新互联公司为所有大学生创业者提供下城建站搭建服务,24小时服务热线:18982081108,官方网址:www.cdcxhl.com

使用Spring Data JPA如何实现多条件的分页查询?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

话不多说,请看代码:

public Map getWeeklyBySearch(final Map serArgs,
      String pageNum, String pageSize) throws Exception {
    // TODO Auto-generated method stub
    Map resultMap=new HashMap();
    // 判断分页条件
    pageNum = TextUtils.isNotBlank(pageNum) ? pageNum : "1";
    pageSize = TextUtils.isNotBlank(pageSize) ? pageSize : "10";
    // 分页时的总页数、每页条数、排序方式、排序字段
    Pageable StuPageable = PageUtils.buildPageRequest(Integer.valueOf(pageNum),Integer.valueOf(pageSize), new Sort(Direction.DESC, new String[] { "xmzbsj","lstProinfo.proId"}));
    // 按照条件进行分页查询,根据StuPageable的分页方式
     Page StuPage = proWeeklyDao.findAll(new Specification() {
      public Predicate toPredicate(Root root, CriteriaQuery<?> query, CriteriaBuilder cb) {
        List lstPredicates = new ArrayList();
        if (TextUtils.isNotBlank(serArgs.get("xmmc"))) {
          lstPredicates.add(cb.like(root.get("lstProinfo").get("xmmc").as(String.class), "%" + serArgs.get("xmmc") + "%"));
        }
        if (TextUtils.isNotBlank(serArgs.get("xmzbqssj"))) {
          lstPredicates.add(cb.greaterThanOrEqualTo(root.get("xmzbsj").as(String.class),serArgs.get("xmzbqssj")));
        }
        if (TextUtils.isNotBlank(serArgs.get("xmzbjzsj"))) {
          lstPredicates.add(cb.lessThanOrEqualTo(root.get("xmzbsj").as(String.class),serArgs.get("xmzbjzsj")));
        }
        Predicate[] arrayPredicates = new Predicate[lstPredicates.size()];
        return cb.and(lstPredicates.toArray(arrayPredicates));
      }
    }, StuPageable);
     // 按照条件进行分页查询
    resultMap = PageUtils.getPageMap(StuPage);
    return resultMap;
  }

网站标题:使用SpringDataJPA如何实现多条件的分页查询-创新互联
分享地址:http://bzwzjz.com/article/deggsj.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站制作公司 重庆网站建设 网站制作公司 成都网站设计 成都商城网站建设 网站设计 攀枝花网站设计 成都网站设计 专业网站设计 app网站建设 成都响应式网站建设 手机网站建设 网站制作 成都网站建设 高端定制网站设计 上市集团网站建设 成都网站建设公司 成都网站建设推广 成都网站设计 成都网站制作 营销型网站建设 企业网站设计