首先继承JpaSpecificationExecutor<T>接口

需要用到JpaSpecificationExecutor<T>中的Page<T> findAll(@Nullable Specification<T> spec, Pageable pageable);//多条件分页查询

ITpSamplerInfoService.java

Page<TpSamplerInfo> findByConditionPage(Long samplerCode,String crossName,Pageable pageable);

TpSamplerInfoServiceImpl.java实现类

@Autowired
ITpSamplerInfoDao samplerInfoDao;//继承JpaSpecificationExecutor<T>

@Override
public Page<TpSamplerInfo> findByConditionPage(Long samplerCode,String crossName, Pageable pageable) {
Page<TpSamplerInfo> pageList = samplerInfoDao.findAll(new Specification<TpSamplerInfo>() {
@Override
public Predicate toPredicate(Root<TpSamplerInfo> root, CriteriaQuery<?> query,
CriteriaBuilder criteriaBuilder) {
List<Predicate> list = new ArrayList<Predicate>();
if(samplerCode!=null) {
list.add(criteriaBuilder.like(root.get("samplerCode"), "%"+samplerCode+"%"));
}
if(crossName!=null) {
//外键对象的属性,要用join再get
list.add(criteriaBuilder.like(root.join("tpCrossroadInfo").get("crssroadName"), crossName));
}
Predicate[] array = new Predicate[list.size()];
return criteriaBuilder.and(list.toArray(array));
}
},pageable);
return pageList;
}
//例子2,查询时间段内的记录
@Override
public Page<MapPack> findAll(Integer code, String startData, String endData, Pageable pageable) {
Page<MapPack> pageList = getMapPackDao().findAll(new Specification<MapPack>() { @Override
public Predicate toPredicate(Root<MapPack> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
List<Predicate> list = new ArrayList<Predicate>(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
SimpleDateFormat sdfmat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); if (StringUtils.isNotEmpty(startData) && StringUtils.isNotEmpty(endData)) {
try {
list.add(cb.between(root.get("registerTime"),
sdfmat.parse(sdfmat.format(sdf.parse(startData).getTime())),
sdfmat.parse(sdfmat.format(sdf.parse(endData).getTime() + 86400000))));
} catch (ParseException e) {
e.printStackTrace();
}
}
if(code!=-1) {
list.add(cb.equal(root.join("city").get("id").as(String.class), code));
}
Predicate[] array = new Predicate[list.size()];
return cb.and(list.toArray(array));
}
}, pageable);
return pageList;
}

  

  

 controller

@RequestMapping("/getAllSamplerInfo")
public Map<String,Object> findByConditionPage(@RequestParam("pageNumber") int page,@RequestParam("pageSize") int size,
@RequestParam("samplerCode") Long samplerCode,@RequestParam("crossName") String crossName){
Map<String,Object> map = new HashMap<String, Object>();
Pageable pageable = PageRequest.of(page-1, size, Direction.DESC, "id");
Page<TpSamplerInfo> pageList = tpSamplerInfoService.findByConditionPage(samplerCode,crossName, pageable);
//使用值对象Vo包装一下实体类,解决递归问题
List<TpSamplerInfoVo> list = new ArrayList<>();
pageList.forEach(pl->{
TpSamplerInfoVo tpVo = new TpSamplerInfoVo(pl);
list.add(tpVo);
});
map.put("rows", list);
map.put("total", pageList.getTotalElements()); return map; }

注意:在多条件查询时候查询id主键的时候遇到过一个错误

Parameter value [%3%] did not match expected type [java.lang.Long (n/a)]      意思是参数不匹配预期类型,id是Long类型

解决办法:list.add(criteriaBuilder.like(root.get("id").as(String.class), "%"+crossId+"%"));

加上as(String.class)就不会出现类型不匹配的问题

 

jpa多条件查询的更多相关文章

  1. jpa多条件查询重写Specification的toPredicate方法(转)

    Spring Data JPA支持JPA2.0的Criteria查询,相应的接口是JpaSpecificationExecutor.Criteria 查询:是一种类型安全和更面向对象的查询 . 这个接 ...

  2. springboot jpa 多条件查询(多表)

    前几天写的,贴上来. 实体类. package com.syl.demo.daomain; import lombok.Data; import javax.persistence.*; /** * ...

  3. springboot jpa 多条件查询(单表)

    需要实现的功能: 多个搜索输入框:全部不填,则查出所有列表:填了条件,就按条件查找:填的条件个数不定. 方法实现的核心:jpa自带的Specification<T> (目前只需要单表,多表 ...

  4. Spring Boot Jpa 多条件查询+排序+分页

    事情有点多,于是快一个月没写东西了,今天补上上次说的. JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将 ...

  5. spring data jpa 组合条件查询封装

    /** * 定义一个查询条件容器 * @author lee * * @param <T> */ public class Criteria<T> implements Spe ...

  6. spring jpa : 多条件查询

    https://www.cnblogs.com/Donnnnnn/p/6277872.html 方式一: 第一步:EmpAccNumService package com.payease.scford ...

  7. 【JPA】表达条件查询的关键字

    1.通过解析方法名创建查询 框架在进行方法名解析时,会先把方法名多余的前缀截取掉,比如 find.findBy.read.readBy.get.getBy,然后对剩下部分进行解析.并且如果方法的最后一 ...

  8. Spring Data JPA,一种动态条件查询的写法

    我们在使用SpringData JPA框架时,进行条件查询,如果是固定条件的查询,我们可以使用符合框架规则的自定义方法以及@Query注解实现. 如果是查询条件是动态的,框架也提供了查询接口. Jpa ...

  9. Spring MVC和Spring Data JPA之按条件查询和分页(kkpaper分页组件)

    推荐视频:尚硅谷Spring Data JPA视频教程,一学就会,百度一下就有, 后台代码:在DAO层继承Spring Data JPA的PagingAndSortingRepository接口实现的 ...

随机推荐

  1. 2.Windows服务-->安装卸载服务

    1.使用vs组件“VS2012开发人员命令提示” 工具,进行安装卸载服务(必须以“管理员身份运行") 安装和卸载的时候选择合适的安装程序工具地址,例如: 安装服务:C:\Windows\Mi ...

  2. PHP5中Static和Const关键字

    (1) static static要害字在类中是,描述一个成员是静态的,static能够限制外部的访问,因为static后的成员是属于类的,是不属于任何对象实例,其他类是无法访问的,只对类的实例共享, ...

  3. Rabbit的事务

    加入事务的方法: txSelect()  txCommit()  txRollback() 生产者: package com.kf.queueDemo.transactions; import jav ...

  4. 问题小记(MyBatis传参出现的小问题)

    问题一:在MyBatis中注解@Param和ParameterType不能一起用,会报错Parameter 'XXX' not found. Available parameters are [1, ...

  5. thinkphp session设置

    <?php namespace Home\Controller; use think\Controller; /*登录*/ class LoginController extends Publi ...

  6. float、display和流

    一.css的元素有很深的道理和它存在的意义 块元素:默认元素的上下左右会有间隔(即使设置margin.padding为0也一样).如果想0间隔,考虑float. float:会使元素自动生成一个块级框 ...

  7. sass语法一(变量篇)

    文件后缀名 sass有两种后缀名的文件:一种后缀名为sass,不使用大括号和分号:另一种是我们这里使用的scss文件,这种和我们平时使用的css文件格式差不多,使用大括号和分号. //后缀名为sass ...

  8. ArcEngine交互画线

    代码 Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-- ...

  9. Python爬虫教程-31-创建 Scrapy 爬虫框架项目

    本篇是介绍在 Anaconda 环境下,创建 Scrapy 爬虫框架项目的步骤,且介绍比较详细 Python爬虫教程-31-创建 Scrapy 爬虫框架项目 首先说一下,本篇是在 Anaconda 环 ...

  10. HTTP协议(持续更新)

    http请求由三部分组成,分别是:请求行.消息报头.请求正文 HTTP(超文本传输协议)是一个基于请求与响应模式的.无状态的.应用层的协议,常基于TCP的连接方式,HTTP1.1版本中给出一种持续连接 ...