当前位置: 首页 > news >正文

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

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

所属类别fid物料编号bm物料批次pc
110.01.0220240807
110.01.0320240807        
210.02.0120240805

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>;

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

http://www.lryc.cn/news/420300.html

相关文章:

  • 使用ollama取代openai的api进行graphRAG失败记录
  • MyBatis 配置与测试方式
  • C#实现代理服务器
  • react的路由实战使用
  • python 字典转成类 构建类
  • springboot 过滤器
  • 【C语言篇】深入理解指针1
  • IAP程序升级 与 电脑BIOS 的关系
  • Java使用MQTT协议
  • 等级+时间的优先级算法
  • 物流仓库安全视频智能管理方案:构建全方位、高效能的防护体系
  • jackson反序列化漏洞
  • Java | Leetcode Java题解之第328题奇偶链表
  • 100 Exercises To Learn Rust 挑战!准备篇
  • 瑞_RabbitMQ_初识MQ
  • 系统内存管理:虚拟内存、内存分段与分页、页表缓存TLB以及Linux内存管理
  • Java每日一练_模拟面试题5(堆和栈的区别)
  • 传感器校正和测试
  • Eclipse 悬浮提示:提高编程效率的利器
  • Vault系列之:创建令牌
  • 如何在 Windows 10 环境下安装和配置 MySQL:初学者指南
  • Ubuntu 24.04上报:Error: could not connect to ollama app, is it running?的解决方法
  • 字典树查重(到底要开多大的空间啊)
  • 财务会计与管理会计(二)
  • 技术周总结 08.05-08.11周日
  • B树和B+树的插入、删除
  • Axios网络请求总结
  • 立仪科技光谱共焦应用之金属隔膜静态重复性测量
  • vue3实现video视频+弹幕评论
  • STM32-OTA升级