zoukankan      html  css  js  c++  java
  • SpringData学习04

    滴水穿石

    之前的 Repository 的分页不支持传参,怎么破? ...实现 JpaSpecificationExecutor<T> 接口

     service 层

      /**
         * Specification<T> : 封装了 JPA Criteria 查询的查询条件
         * Pageable : 封装了请求分页的信息
         * */
        public Page<Person> findByJpaSpecificationExecutor(Specification<Person> spec,Pageable pageable){
            return pRepository.findAll(spec, pageable);
        }

    单元测试

    /**
         * 实现带查询条件的分页
         * */
        @Test
        public void testJpaSpecificationExecutor(){
            int page = 3 - 1;
            int size = 5;
            PageRequest pageable = new PageRequest(page, size);
            
            Specification<Person> spec = new Specification<Person>() {
                /**
                 * *root : 代表查询的实体类
                 * query : 从中可得到Root对象,即告知JPA Criteria 查询要查询哪一个实体类
                 *             还可以用来添加查询条件,
                 *             还可以结合EntityManager 对象得到最终查询的 TypedQuery 对象
                 * *cb : CriteriaBuilder对象,用于创建 Criteria相关对象的工厂,当然可以从中获取Predicate对象
                 * *Predicate : 代表一个查询条件
                 * */
                @Override
                public Predicate toPredicate(Root<Person> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
                    Path path = root.get("id");
                    Predicate predicate = cb.gt(path, 5);
                    return predicate;
                }
                
            };
            
            Page<Person> plist = pService.findByJpaSpecificationExecutor(spec, pageable);
            
            System.out.println("总条数: " + plist.getTotalElements());
            System.out.println("总页数: " + plist.getTotalPages());
            System.out.println("当前页数: " + (plist.getNumber()+1));
            System.out.println("当前页面记录数: " + plist.getNumberOfElements());
            System.out.println("当前页面List: " + plist.getContent());
        }
        

    测试结果

    当前页数 为  21 , "xxx" + 2 + 1 ; 不能忽略呀 要写成 “xxxx” + (2+1) 哦

    这个方式工作中肯定是不科学的,需要构建一个通用的Base类。

    自定义方法

    —————————————————————————————————————————————————————————————————————————

    无论如何,心平气和

  • 相关阅读:
    第一次作业-准备篇
    个人作业——软件工程实践总结&个人技术博客
    个人技术总结-spring boot编写接口和数据返回
    个人作业——软件评测
    结对第二次作业——某次疫情统计可视化的实现
    结对第一次—疫情统计可视化(原型设计)
    软工实践寒假作业(2/2)
    软工实践寒假作业(1/2)
    个人作业-软件工程实践总结
    Android实现多图选择
  • 原文地址:https://www.cnblogs.com/cfb513142804/p/7234397.html
Copyright © 2011-2022 走看看