jpa Specification动态查询分页-实例

本文介绍如何使用 Spring Data JPA 实现基于 Specification 的动态查询,包括分页查询、不分页查询及仅分页的功能实现。通过具体示例展示了如何构建 Predicate 条件并进行灵活的数据检索。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作者:LoveEmperor-王子様

1.Specification接口中定义了如下一个方法:

Predicate toPredicate(Root<T> root, CriteriaQuery<?> query, CriteriaBuilder cb);

一、动态查询分页应用代码示例:
controller接口:

    @PostMapping("/xx-xx-xx")
    @Timed
    public Page<InvoiceInfo> getAllInvoiceInfos(@Valid @RequestBody InvoiceListVo vo) throws Exception{
        log.debug("REST request to get all InvoiceInfos");

        return invoiceInfoService.findByCondition(vo);
    }

service方法:

    public Page<InvoiceInfo> findByCondition(InvoiceListVo vo) {
        Pageable pageable = new PageRequest(vo.getPageNumber(), vo.getPageSize(), Sort.Direction.ASC, "id");

        Page<InvoiceInfo> page = this.invoiceInfoRepository.findAll(getCondition(vo), pageable);

        return page;
    }
    private Specification<InvoiceInfo> getCondition(InvoiceListVo vo){
        Specification<InvoiceInfo> sp = new Specification<InvoiceInfo>() {
            /**
             * @param root root参数是我们用来对应实体的信息的。
             * @param query
             * @param cb criteriaBuilder可以帮助我们制作查询信息。
             * @return
             */
            @Override
            public Predicate toPredicate(Root<InvoiceInfo> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
                // 创建 Predicate
                Predicate predicate = cb.conjunction();
                // 组装条件
                if(!vo.getPhone().equals("0")){
//                    predicate.add(cb.equal(root.get("phone"), vo.getPhone()));
                    predicate.getExpressions().add(cb.equal(root.get("phone"), vo.getPhone()));
                }
                if(0 != vo.getTitleType()){
                    predicate.getExpressions().add(cb.equal(root.get("titleType"), vo.getTitleType()));
                }
                if(null != vo.getInvoiceTitle()){
                    predicate.getExpressions().add(cb.equal(root.get("invoiceTitle"), "%"+vo.getInvoiceTitle()+"%"));
                }
                return predicate;
            }

        };
        return sp;
    }

JpaRepository:

@SuppressWarnings("unused")
@Repository
public interface InvoiceInfoRepository extends JpaRepository<InvoiceInfo, Long>,JpaSpecificationExecutor<InvoiceInfo> {
}

二、动态查询不分页:

    public List<InvoiceInfo> findByCondition(InvoiceListVo vo){
        List<InvoiceInfo> resultList = null;
        Specification querySpecifi = new Specification<InvoiceInfo>() {
            @Override
            public Predicate toPredicate(Root<InvoiceInfo> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {

                List<Predicate> predicates = new ArrayList<>();
                if(!vo.getPhone().equals("0")){
                    predicates.add(criteriaBuilder.equal(root.get("phone"), vo.getPhone()));
                }
                if(0 != vo.getTitleType()){
                    predicates.add(criteriaBuilder.equal(root.get("titleType"), vo.getTitleType()));
                }
                if(null != vo.getInvoiceTitle()){
                    predicates.add(criteriaBuilder.equal(root.get("invoiceTitle"), "%"+vo.getInvoiceTitle()+"%"));
                }
                return criteriaBuilder.and(predicates.toArray(new Predicate[predicates.size()]));
            }
        };
        resultList =  this.invoiceInfoRepository.findAll(querySpecifi);
        return resultList;
    }

三、只分页查询:

    @Transactional(readOnly = true)
    public Page<InvoiceInfo> findAll(Integer page,Integer size) {
        Pageable pageable = new PageRequest(page, size, Sort.Direction.ASC, "id");
        return invoiceInfoRepository.findAll(pageable);

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

王子様~

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

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

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

打赏作者

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

抵扣说明:

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

余额充值