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());
    	}
    

      

  • 相关阅读:
    sql 查询多列 小于某值
    C#读取EXCEL 并输出到文本框
    字典
    MVC 接收文件
    C# DataTable 转 json
    MVC 返回json数据
    C# 获得指定路径扩展名 , 去除扩展名
    C# 分割URL地址
    sql语句参数化问题
    VC++学习之网络编程中的套接字
  • 原文地址:https://www.cnblogs.com/airycode/p/6536597.html
Copyright © 2011-2022 走看看