zoukankan      html  css  js  c++  java
  • 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());
    	}
    

      

  • 相关阅读:
    1107 Social Clusters (30分)
    1108 Finding Average (20分)
    1109 Group Photo (25分)
    js-字符串(String)方法大全
    js-数组(Array)方法大全
    js-产生随机验证码的具体案例
    js-事件细节详解以及案例
    js-数据类型转换(强制转换、隐式转换)和数据运算符(包含三目运算符)详解
    css3-文本阴影(text-shadow)和盒子阴影(box-shadow)详解及其案例
    css3-动画animation详解及其案例
  • 原文地址:https://www.cnblogs.com/airycode/p/6536597.html
Copyright © 2011-2022 走看看