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 片段
相关推荐
敲代码的彭于晏24 分钟前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev2 小时前
ButterKnife → ViewBinding
android·java·kotlin
唐青枫2 小时前
别再只会用 cron:Linux systemd Timer 定时任务实战详解
linux
像我这样帅的人丶你还17 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩18 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia18 小时前
Mybatis的日志输入
java
亦暖筑序20 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端
Yeats_Liao1 天前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿1 天前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试