lambdaQuery 加 or

在 MyBatis-Plus 中,LambdaQueryWrapper.or() 用于拼接 SQL 的 OR 条件。核心难点在于条件优先级与括号分组,使用不当会导致 SQL 逻辑与预期不符。

🔹 1. 基础用法(仅作用于下一个条件)

复制代码
复制代码
lambdaQuery()
    .eq(User::getName, "Alice")
    .or()                    // ⚠️ 只影响紧随其后的一个条件
    .eq(User::getAge, 25)
    .list();
// 生成 SQL: WHERE name = 'Alice' OR age = 25

🔹 2. 推荐用法:使用 Lambda 分组(自动加 ()

当需要 AND (A OR B)OR (A AND B) 时,务必使用 and(Consumer) / or(Consumer),框架会自动处理括号。

复制代码
复制代码
lambdaQuery()
    .eq(User::getStatus, 1)
    .and(wrapper -> wrapper   // 生成外层 AND (...)
        .eq(User::getName, "Alice")
        .or()
        .eq(User::getAge, 25)
    )
    .list();
// 生成 SQL: WHERE status = 1 AND (name = 'Alice' OR age = 25)

🔹 3. 复杂多条件 OR 示例

复制代码
复制代码
lambdaQuery()
    .eq(User::getStatus, 1)
    .or(wrapper -> wrapper    // 生成 OR (...)
        .like(User::getName, "张")
        .or()                 // 括号内部的 OR
        .like(User::getName, "李")
    )
    .list();
// 生成 SQL: WHERE status = 1 OR (name LIKE '%张%' OR name LIKE '%李%')

⚠️ 关键注意事项

写法 生成 SQL 是否推荐
.eq(A).or().eq(B).eq(C) WHERE A OR B AND C ❌ 易错,AND 优先级高于 OR
.eq(A).or(wrapper->wrapper.eq(B).eq(C)) WHERE A OR (B AND C) ✅ 安全明确
连续多个 .or() WHERE A OR B OR C ✅ 仅限纯并列 OR
  1. 无参 or() 只"管"下一个条件,不会自动分组。
  2. 永远用 and(Consumer) / or(Consumer) 包裹组合条件,避免优先级陷阱。
  3. MyBatis-Plus 3.x 均支持 Lambda 分组,无需额外配置。
  4. 若使用 service.lambdaQuery(),底层自动构建 LambdaQueryWrapper,写法完全一致。

💡 调试技巧

生成 SQL 前可打印 Wrapper 确认逻辑:

复制代码
复制代码
LambdaQueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery()
    .eq(User::getStatus, 1)
    .and(w -> w.eq(User::getName, "Alice").or().eq(User::getAge, 25));

System.out.println(wrapper.getSqlSegment()); // 查看实际 SQL 片段
相关推荐
ℳ₯㎕ddzོꦿ࿐1 小时前
实战:在 Linux 系统用 Docker-Compose 优雅部署 GitLab 及防坑指南
linux·docker·gitlab
源图客1 小时前
Linux(CentOS9)服务器部署gitlab-ce-18.11.1-ce.0.el9.x86_64.rpm
linux·服务器·gitlab
天涯海风1 小时前
写一个录音并保存到手机的工具 安卓工具类
android·java·智能手机
原来是猿1 小时前
网络命令入门:Ping、Netstat 和 Pidof 详解
linux·运维·服务器
sjsjsbbsbsn1 小时前
RAG 基础学习总结
java·数据库·学习
汽车仪器仪表相关领域1 小时前
Kvaser Memorator Light HS v2:单通道 CAN FD 便携记录仪,即插即用的故障诊断利器
运维·服务器·数据库·人工智能·功能测试·单元测试
H Journey1 小时前
常用知识总结C++、CMake、Linux
linux·c++·opencv·cmake
今天又在写代码2 小时前
Docker部署
java·阿里云·docker
Z文的博客2 小时前
嵌入式LINUX QT 开发 .gitignore 文件编写指南
linux·git·qt·elasticsearch·嵌入式