spring boot jpa 中 Specification的操作

@Override
    public Page<ParkVisit> list(String day,
                                String visitStratTime,
                                String visitEndTime, Integer parkId, String checkStatus,
                                String parkName, Integer id, String visitorUserName,String userName
    ) throws Exception {
        Page<ParkVisit> parkVisits = null;
        try {
            parkVisits = parkVisitDao.findAll(new Specification<ParkVisit>() {
                @Override
                public Predicate toPredicate(Root<ParkVisit> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder cb){
                    List<Predicate> predicateList = new ArrayList<>();
                    List<Predicate> orList = new ArrayList<>();

                    if (StringUtil.isNotEmpty(visitStratTime)) {
                        predicateList.add(cb.greaterThanOrEqualTo(root.get("visitTime").as(String.class), visitStratTime));
                    }
                    if (StringUtil.isNotEmpty(visitEndTime)) {
                        predicateList.add(cb.lessThanOrEqualTo(root.get("visitTime").as(String.class).as(String.class), visitEndTime));
                    }
                    if (parkId != null) {
                        predicateList.add(cb.equal(root.get("parkId").as(String.class), parkId));
                    }


                    if ("5".equals(checkStatus) || "8".equals(checkStatus)) {
                        predicateList.add(
                                cb.or(
                                        cb.equal(root.get("checkStatus"), "5"),
                                        cb.equal(root.get("checkStatus"), "8")
                                )
                        );


                        int i = checkStatus.indexOf(",");
                        if (i <= 0) { //单状态
                            predicateList.add(cb.equal(root.get("checkStatus")
                                    .as(String.class), checkStatus));
                        } else {
                            //多状态 zgState="审核,未审核,待审核"
                            String[] split = zgState.split(",");
                            Expression<String> states = root.<String>get("checkStatus");
                            predicateList.add(states.in(split)); // 往in中添加所有状态
                        }


                        List<Predicate> listOr = new ArrayList<Predicate>();
                        if (StringUtil.isNoEmpty(userName)) {
                            String[] split = userName.split(",");
                            if (split.length <= 1) {
                                predicateList.add(criteriaBuilder.like(root.get(userName), "%" + userName + "%"));
                            } else {
                                Predicate userName2 = null;
                                for (String item : split) {
                                    userName2 = criteriaBuilder.like(root.get("userName").as(String.class), "%" + item + "%");
                                    listOr.add(criteriaBuilder.or(userName2));
                                }
                            }

                        }

                        Predicate[] arrayOr = new Predicate[listOr.size()];
                        Predicate or = cb.or(listOr.toArray(arrayOr));

                        Predicate[] pre = new Predicate[predicateList.size()];
                        Predicate and = cb.and(predicateList.toArray(pre));

                        if (listOr.size() > 0) return criteriaQuery.where(and, or).getRestriction();
                        else return criteriaQuery.where(and).getRestriction();

						/*
						Predicate[] pre = new Predicate[predicateList.size()];
                    	criteriaQuery.where(predicateList.toArray(pre));
                    	return cb.and(predicateList.toArray(pre));
 
                        List<Order> orderList = new ArrayList();
                        orderList.add(cb.desc(root.get("sort")));
                        cb.orderBy(orderList);

                        return cb.and(predicateList.toArray(pre));*/
                    }
                });
            }catch(Exception e){
                log.error("ParkVisitServiceImpl list Error:" + e);
                throw e;
            }
            return parkVisits;
        }

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小张帅三代

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值