springboot mybatis plus 固定查询条件及可选查询条件的组合查询,使用QueryWrapper.and()来解决。

1、我们在写查询SQL的时候,经常会碰到,比如,同一个类别下的某一个编号的物料信息,或者是同一批次的物料库存问题等等。

|---------|----------|----------|
| 所属类别fid | 物料编号bm | 物料批次pc |
| 1 | 10.01.02 | 20240807 |
| 1 | 10.01.03 | 20240807 |
| 2 | 10.02.01 | 20240805 |

2、那么我们要查询fid=1下面的可选条件bm=10.01.02或者pc=20240807的

那么我们的where fid=1 and (bm='10.01.02' or pc='20240807')

3、有二种方法实现,一种是直接sql,然后判断去处理就行,另一种是用QueryWrapper来直接写,这里我们用QueryWrapper实现:

复制代码
QueryWrapper<Materials> queryWrapper = new QueryWrapper<>();
queryWrapper.eq(materials.getFid() != null, "fid", materials.getFid());

上面是固定的条件,那么可选条件的:

复制代码
queryWrapper.and(query -> query.like(materials.getBm()!=null, "bm", materials.getBm()).or().
 like(materials.getPc()!=null, "pc", materials.getPc()));

4、通过上面的编写,我们就可以实现where fid=1 and (bm='10.01.02' or pc='20240807')的效果,也就是queryWrapper.and()来编写就可以了,这个会在在where + and (多个条件)。

5、然后实际开发中,并不是这么简单,会有这种情况,有多个条件,而且查询条件有些复杂的情况,比如下面的图中的实现:

那么在后端的代码编写,就不可以直接通过字段来一个一个的判断加入了。

6、对于动态的字段,及取值的情况我们可以这么写:

复制代码
queryWrapper.and((wrapper) -> {
				dynamicConditions.entrySet().stream().forEach((entry) -> {
					wrapper.or().like(entry.getKey(), entry.getValue());
				});
			});

说明:dynamicConditions:这个是HashMap<String,Object>;

这样,我们就可以动态的处理,而且是成功实现了。

相关推荐
智能工业品检测-奇妙智能几秒前
AIFlowy如何实现与现有Spring Boot项目的无缝集成?
java·spring boot·后端
Ama_tor4 分钟前
Flask零基础进阶(中)
后端·python·flask
人道领域8 分钟前
苍穹外卖:菜品新增功能全流程解析
数据库·后端·状态模式
野犬寒鸦13 分钟前
TCP协议核心:TCP详细图解及TCP与UDP核心区别对比(附实战解析)
服务器·网络·数据库·后端·面试
05大叔17 分钟前
Mybatis-Plus
java·开发语言·mybatis
Predestination王瀞潞18 分钟前
缓存机制:一二级缓存
spring·缓存·mybatis
一知半解仙22 分钟前
从“玩具项目“到“生产级架构“:Spring Boot + Spring Cloud + AI 微服务实战避坑指南
spring boot·spring cloud·架构
毕设源码-朱学姐22 分钟前
【开题答辩全过程】以 基于springBoot微服务架构的老年人社交系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
Mr.朱鹏25 分钟前
分布式-redis主从复制架构
java·spring boot·redis·分布式·缓存·架构·java-ee
csdn_aspnet39 分钟前
Asp.Net Core 10.0 中的 Blazor 增强功能
前端·后端·asp.net·blazor·.net10