springDataJpa多条件动态查询之JpaSpecificationExecutor

本文主要是介绍springDataJpa多条件动态查询之JpaSpecificationExecutor,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在spring中多条件动态查询:

准备实体表:

多条件查询,加上排序 

 /*** 排序加上查询* 模糊查询 用户名 和 密码 和 状态*/@Testpublic void  testQuery(){Specification<Student> specification = new Specification<Student>() {@Overridepublic Predicate toPredicate(Root<Student> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {// 1.root获取比较属性Path<String> username = root.get("username");Path<String> password = root.get("password");Path<Boolean> isDel = root.get("isDel");// 2.criteriaBuilder构造查询条件Predicate like = criteriaBuilder.like(username, "%用户名%");Predicate like1 = criteriaBuilder.like(password, "%码%");Predicate equal = criteriaBuilder.equal(isDel, false);// 级联条件,可以用 and 或者 orPredicate and = criteriaBuilder.and(like, like1, equal);// 返回查询条件return and;}};// 新建排序条件,按照成绩这一字段 降序排列Sort sort = new Sort(Sort.Direction.DESC,"grade");// 调用查询方法。把拼接的条件传入List<Student> all = studentRepository.findAll(specification,sort);for (Student student : all) {System.out.println(student);}}

结果:

 

多条件查询,分页加排序

/**** 多条件查询,在多个查询满足 用户名和多个成绩的数据* 分页加上排序*/@Testpublic void queryTest(){List<Integer> list = new ArrayList<>();list.add(1);list.add(2);list.add(3);list.add(4);Specification<Student> specification = new Specification<Student>() {@Overridepublic Predicate toPredicate(Root<Student> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder criteriaBuilder) {Path<String> username = root.get("username");Path<Integer> grade = root.get("grade");Predicate like = criteriaBuilder.like(username, "%名%");CriteriaBuilder.In<Integer> in = criteriaBuilder.in(grade);CriteriaBuilder.In<Integer> value=null;for (Integer integer : list) {value = in.value(integer);}// 拼接条件返回return criteriaBuilder.and(like, value);}};// 创建排序条件Sort sort = new Sort(Sort.Direction.DESC, "grade");// 创建分页条件 page为当前页 size为每页显示条数Pageable pageRequest = new PageRequest(1-1,10,sort);// 将条件和分页传入,返回pagePage<Student> all = studentRepository.findAll(specification, pageRequest);// 获得查询的数据List<Student> content = all.getContent();for (Student student : content) {System.out.println(student);}System.out.println("总数据数量:"+all.getTotalElements());System.out.println("总页数:"+all.getTotalPages());System.out.println("当前页:"+all.getNumber());System.out.println("当前页显示元素:"+all.getNumberOfElements());System.out.println(all.getPageable());System.out.println("每页显示个数:"+all.getSize());System.out.println("排序规则:"+all.getSort());}

 查询结果

 

 

这篇关于springDataJpa多条件动态查询之JpaSpecificationExecutor的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/749856

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

Java导出Excel动态表头的示例详解

《Java导出Excel动态表头的示例详解》这篇文章主要为大家详细介绍了Java导出Excel动态表头的相关知识,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录前言一、效果展示二、代码实现1.固定头实体类2.动态头实现3.导出动态头前言本文只记录大致思路以及做法,代码不进

MYSQL关联关系查询方式

《MYSQL关联关系查询方式》文章详细介绍了MySQL中如何使用内连接和左外连接进行表的关联查询,并展示了如何选择列和使用别名,文章还提供了一些关于查询优化的建议,并鼓励读者参考和支持脚本之家... 目录mysql关联关系查询关联关系查询这个查询做了以下几件事MySQL自关联查询总结MYSQL关联关系查询

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

查询Oracle数据库表是否被锁的实现方式

《查询Oracle数据库表是否被锁的实现方式》本文介绍了查询Oracle数据库表是否被锁的方法,包括查询锁表的会话、人员信息,根据object_id查询表名,以及根据会话ID查询和停止本地进程,同时,... 目录查询oracle数据库表是否被锁1、查询锁表的会话、人员等信息2、根据 object_id查询被

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要