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

关于MyBatis-Plus 提供Wrappers.lambdaQuery()的方法

实例:

private LambdaQueryWrapper<XXX> buildQueryWrapper(XXXBo bo) { Map<String, Object> params = bo.getParams(); LambdaQueryWrapper<XXX> lqw = Wrappers.lambdaQuery(); lqw.eq(bo.getOrgId() != null, XXX::getOrgId, bo.getOrgId()); lqw.eq(bo.getSupplierId() != null, XXX::getSupplierId, bo.getSupplierId()); lqw.like(bo.getCertigier() != null, XXX::getCertigier, bo.getCertigier()); lqw.like(StringUtils.isNotBlank(bo.getTitle()), XXX::getTitle, bo.getTitle()); lqw.like(StringUtils.isNotBlank(bo.getCode()), XXX::getCode, bo.getCode()); lqw.like(StringUtils.isNotBlank(bo.getAddress()), XXX::getAddress, bo.getAddress()); lqw.eq(bo.getPermission() != null, XXX::getPermission, bo.getPermission()); lqw.eq(bo.getEndTime() != null, XXX::getEndTime, bo.getEndTime()); lqw.like(StringUtils.isNotBlank(bo.getRegCode()), XXX::getRegCode, bo.getRegCode()); lqw.eq(StringUtils.isNotBlank(bo.getRemark()), XXX::getRemark, bo.getRemark()); lqw.eq(StringUtils.isNotBlank(bo.getAgent()), XXX::getAgent, bo.getAgent()); lqw.between(params.get("beginOrderTime") != null && params.get("endOrderTime") != null, XXX::getOrderTime ,params.get("beginOrderTime"), params.get("endOrderTime")); lqw.between(params.get("beginRegTime") != null && params.get("endRegTime") != null, XXX::getRegTime ,params.get("beginRegTime"), params.get("endRegTime")); lqw.orderByDesc(XXX::getId); return lqw; }

这个方法是用于构建一个 LambdaQueryWrapper 对象的,LambdaQueryWrapper 是 MyBatis-Plus 提供的一个用于动态构建 SQL 查询条件的类。你这个方法主要是根据传入的 XXXBo 对象中的参数,来动态生成查询条件。以下是对该方法的详细解读:

1. 获取 params 参数:

Map<String, Object> params = bo.getParams();
这里从 XXX对象中获取了一个 params 字段,通常这是用于保存一些额外的查询参数,比如开始时间和结束时间等。

2. 创建 LambdaQueryWrapper 实例:

LambdaQueryWrar<XXX> lqw = Wrappers.lambdaQuery();
Wrappers.lambdaQuery() 是 MyBatis-Plus 提供的工具方法,创建了一个 LambdaQueryWrapper 对象,该对象用于后续的查询条件链式调用。

3. 动态添加查询条件:

根据不同的字段判断是否添加查询条件:
  • eq():用于等值查询。
  • like():用于模糊查询。
  • between():用于范围查询。
  • 每一个条件都根据对应的字段是否为空(或是否满足某个条件)来动态决定是否加到查询条件中。例如 bo.getId() != null,表示只有当 Id 不为空时,才会将这个字段加入查询条件。
  • like 用于模糊查询,eq 用于精确匹配。

4. 范围查询:

lqw.between(params.get("beginOrderTime") != null && params.get("endOrderTime") != null,
    XXX::getOrderTime ,params.get("beginOrderTime"), params.get("endOrderTime"));
lqw.between(params.get("beginRegTime") != null && params.get("endRegTime") != null,
    XXX::getRegTime ,params.get("beginRegTime"), params.get("endRegTime"));
这部分是对 params 中的 beginOrderTimeendOrderTimebeginRegTimeendRegTime 进行的范围查询。between() 方法的作用是查询某个字段在给定的两个时间之间的记录。

5. 排序:

这行代码表示最终的查询结果会按照 Id 字段降序排列。

总结:

这个方法的核心功能是根据 XXX对象的不同属性,动态生成相应的查询条件,并返回一个 LambdaQueryWrapper,这使得查询可以灵活应对不同的条件组合,符合动态 SQL 查询的需求。

如果有问题或者需要优化的地方,可以进一步讨论。

可以通过 between 方法来实现这个需求,在查询中增加一个 XXX::getId 在 0 到 9900 之间的条件。

你可以在现有的 buildQueryWrapper 方法中,添加如下条件:

lqw.betn(XXX::getId, 0, 9900);
 

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

相关文章:

  • C++——vector的了解与使用
  • Ubuntu设置静态IP地址
  • 力扣349.两个数组的交集
  • FreeRTOS - 软件定时器
  • Python的Atlassian第三方库的详细介绍
  • Java中的基本循环结构详解
  • 关于Git Bash中如何定义alias
  • luckfox1106初次使用
  • ab命令深入解析:ApacheBench性能测试工具
  • VSCode创建VUE项目(二)前端登录页面
  • centos 8.4学习小结
  • AI 设计工具合集
  • mac 源代码安装openresty
  • 人工智能和机器学习之线性代数(二)
  • Postman中的form-data 和 JSON 的区别
  • 网络安全基础知识点_网络安全知识基础知识篇
  • Vue.js 从入门到精通:全面解析组件化、路由与状态管理(附 Todo 案例)
  • AI Weekly#1:过去一周重要的AI资讯汇总
  • 图论刷题
  • ICM20948 DMP代码详解(85)
  • 深入解析:Linux tcpdump命令在网络流量分析中的实战应用
  • Java集合常见知识总结(上)
  • 【算法】力扣:K个一组反转链表
  • Matlab报错——错误使用 vertcat
  • 【如何获取股票数据10】Python、Java等多种主流语言实例演示获取股票行情api接口之沪深A股历史分时KDJ数据获取实例演示及接口API说明文档
  • 进入 Searing-66 火焰星球:第一周游戏指南
  • 考研论坛设计小程序ssm+论文源码调试讲解
  • JAVA笔记 | EasyExcel创建带有简单下拉框的导入模板
  • 【含开题报告+文档+PPT+源码】贫困儿童一对一扶贫帮扶系统设计与实现
  • 多系统萎缩不慌张,这些维生素是你的“隐形盾牌”!️