• SpringData_JpaSpecificationExecutor接口


    • 不属于Repository体系,实现一组 JPA Criteria 查询相关的方法 
    • Specification:封装 JPA Criteria 查询条件。通常使用匿名内部类的方式来创建该接口的对象

    /**
    	 * 目标: 实现带查询条件的分页. id > 5 的条件
    	 * 
    	 * 调用 JpaSpecificationExecutor 的 Page<T> findAll(Specification<T> spec, Pageable pageable);
    	 * Specification: 封装了 JPA Criteria 查询的查询条件
    	 * Pageable: 封装了请求分页的信息: 例如 pageNo, pageSize, Sort
    	 */
    	@Test
    	public void testJpaSpecificationExecutor(){
    		int pageNo = 3 - 1;
    		int pageSize = 5;
    		PageRequest pageable = new PageRequest(pageNo, pageSize);
    		
    		//通常使用 Specification 的匿名内部类
    		Specification<Person> specification = new Specification<Person>() {
    			/**
    			 * @param *root: 代表查询的实体类. 
    			 * @param query: 可以从中可到 Root 对象, 即告知 JPA Criteria 查询要查询哪一个实体类. 还可以
    			 * 来添加查询条件, 还可以结合 EntityManager 对象得到最终查询的 TypedQuery 对象. 
    			 * @param *cb: CriteriaBuilder 对象. 用于创建 Criteria 相关对象的工厂. 当然可以从中获取到 Predicate 对象
    			 * @return: *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> page = personRepsotory.findAll(specification, pageable);
    		
    		System.out.println("总记录数: " + page.getTotalElements());
    		System.out.println("当前第几页: " + (page.getNumber() + 1));
    		System.out.println("总页数: " + page.getTotalPages());
    		System.out.println("当前页面的 List: " + page.getContent());
    		System.out.println("当前页面的记录数: " + page.getNumberOfElements());
    	}
    

      

  • 相关阅读:
    div中子div在firefox ie 水平居中对齐
    Access数据库自定义连接字符串(详细有图百度文档)
    ASP页面乱码
    国内开源asp.netCMS汇总
    sql 2005
    卡巴斯基授权key导入方式方法及其导入key基本原理
    关于SqlServer服务无法启动的症状分析和解决方法
    js下流媒体的在线播放
    用JS+vml作三维报表
    了解嵌入式数据库(sqlite,firebird)
  • 原文地址:https://www.cnblogs.com/airycode/p/6536597.html
Copyright © 2020-2023  润新知