Predicate 条件查询,分页,排序

@RequestMapping(value = "all", method = RequestMethod.GET, produces = "application/json")
    @ResponseBody
    public  List<SysUser> sus1(String s,String d) {
        Pageable pageable = new PageRequest(0,2);
        List<Predicate> list = new ArrayList<>();
        Page<SysUser> all = sysUserRepository.findAll(new Specification<SysUser>() {
            @Override
            public Predicate toPredicate(Root<SysUser> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
                if (StringUtils.isNotBlank(s)) {
                    Predicate names = cb.like(root.get("loginName").as(String.class), "%" + s + "%");
                    list.add(names);
                }
                if (StringUtils.isNotBlank(d)) {
                    Predicate named = cb.equal(root.get("displayName").as(String.class), d);
                    list.add(named);
                }
                Predicate [] predicate = new Predicate[list.size()];
                query.where(cb.and(list.toArray(predicate)));
                query.orderBy(cb.desc(root.get("loginName").as(String.class)));
                return query.getRestriction();
            };
        },pageable);
        return  all.getContent();
    }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值