news 2026/5/24 11:22:06

Mybatis-Plus中QueryWrapper 与 LambdaQueryWrapper 的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Mybatis-Plus中QueryWrapper 与 LambdaQueryWrapper 的区别

QueryWrapper 与 LambdaQueryWrapper 的区别

1.基本区别

QueryWrapper

java

// 使用字符串表示字段名 QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper.eq("name", "张三") .gt("age", 18) .like("email", "@qq.com");

LambdaQueryWrapper

java

// 使用Lambda表达式引用字段 LambdaQueryWrapper<User> lambdaWrapper = new LambdaQueryWrapper<>(); lambdaWrapper.eq(User::getName, "张三") .gt(User::getAge, 18) .like(User::getEmail, "@qq.com");

2.核心区别对比

特性QueryWrapperLambdaQueryWrapper
字段引用方式字符串硬编码Lambda表达式
类型安全性编译期不检查字段是否存在编译期检查,类型安全
重构友好性重命名字段需手动修改字符串IDE自动重构
代码可读性一般更好,直接关联实体类
性能相同相同
防SQL注入都防SQL注入都防SQL注入

3.详细对比

3.1 类型安全性

java

// QueryWrapper - 编译期不报错,运行时报错 queryWrapper.eq("nam", "张三"); // 拼写错误,编译时不检查 // LambdaQueryWrapper - 编译期报错 lambdaWrapper.eq(User::getNam, "张三"); // 编译时报错:找不到getNam方法

3.2 重构友好性

java

// QueryWrapper - 重命名需要手动修改 // 假设把字段 name 改为 username queryWrapper.eq("name", "张三"); // ❌ 需要手动改为 "username" // LambdaQueryWrapper - IDE自动重构 lambdaWrapper.eq(User::getName, "张三"); // ✅ 重命名实体类字段时自动更新

3.3 复杂查询对比

java

// QueryWrapper QueryWrapper<CapitalInfo> queryWrapper = new QueryWrapper<>(); if (StringUtils.isNotBlank(capitalName)) { queryWrapper.like("capital_name", capitalName); } if (capitalYear != null) { queryWrapper.eq("capital_year", capitalYear); } // LambdaQueryWrapper LambdaQueryWrapper<CapitalInfo> lambdaWrapper = new LambdaQueryWrapper<>(); lambdaWrapper.like(StringUtils.isNotBlank(capitalName), CapitalInfo::getCapitalName, capitalName) .eq(capitalYear != null, CapitalInfo::getCapitalYear, capitalYear);

4.实际使用示例

QueryWrapper 使用场景

java

// 1. 动态字段名(字段名是变量) String fieldName = getFieldNameFromRequest(); // 可能是 "name" 或 "username" QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.eq(fieldName, "张三"); // Lambda方式无法实现 // 2. 复杂动态SQL拼接 QueryWrapper<User> wrapper = new QueryWrapper<>(); if (condition1) { wrapper.eq("field1", value1); } else { wrapper.isNull("field1"); } if (condition2) { wrapper.in("field2", Arrays.asList(1, 2, 3)); } // 3. 表连接查询 QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.eq("u.status", 1) .eq("r.role_type", "admin") .apply("u.role_id = r.id");

LambdaQueryWrapper 使用场景

java

// 1. 常规查询(推荐) LambdaQueryWrapper<CapitalInfo> wrapper = new LambdaQueryWrapper<>(); wrapper.eq(CapitalInfo::getCapitalState, 1) .like(CapitalInfo::getCapitalName, "测试") .orderByDesc(CapitalInfo::getCreateTime); // 2. 链式调用 List<CapitalInfo> list = capitalInfoMapper.selectList( new LambdaQueryWrapper<CapitalInfo>() .eq(CapitalInfo::getCapitalYear, 2024) .in(CapitalInfo::getCapitalType, Arrays.asList("A", "B", "C")) .groupBy(CapitalInfo::getCapitalSource) ); // 3. 条件判断简化 LambdaQueryWrapper<CapitalInfo> wrapper = new LambdaQueryWrapper<>(); wrapper.eq(queryDTO.getCapitalState() != null, CapitalInfo::getCapitalState, queryDTO.getCapitalState()) .like(StringUtils.isNotBlank(queryDTO.getCapitalName()), CapitalInfo::getCapitalName, queryDTO.getCapitalName());

5.性能比较

两者在性能上没有区别,最终都会转换为相同的SQL语句:

sql

-- 两者生成的SQL相同 SELECT * FROM capital_info WHERE capital_state = 1 AND capital_name LIKE '%测试%' ORDER BY create_time DESC

6.最佳实践建议

推荐使用 LambdaQueryWrapper 的情况:

  1. 查询条件固定,字段名不会动态变化

  2. 注重代码可维护性和类型安全

  3. 实体类字段可能重构的情况

  4. 新项目开发,优先使用Lambda方式

推荐使用 QueryWrapper 的情况:

  1. 字段名需要动态生成

  2. 多表连接查询,涉及多个表的字段

  3. 处理遗留代码,保持一致性

  4. 构建复杂动态SQL,使用字符串更灵活

7.混合使用示例

java

// 可以使用QueryWrapper的lambda()方法 QueryWrapper<CapitalInfo> wrapper = new QueryWrapper<>(); wrapper.lambda() // 转换为Lambda方式 .eq(CapitalInfo::getCapitalState, 1) .like(CapitalInfo::getCapitalName, "测试"); // 或者反过来 LambdaQueryWrapper<CapitalInfo> lambdaWrapper = new LambdaQueryWrapper<>(); lambdaWrapper.eq(CapitalInfo::getCapitalState, 1); QueryWrapper<CapitalInfo> queryWrapper = lambdaWrapper.getWrapper(); // 可以继续添加字符串方式的查询条件 queryWrapper.apply("DATE(create_time) = CURDATE()");

8.结论

方面推荐原因
新项目开发LambdaQueryWrapper类型安全,重构友好
字段名固定LambdaQueryWrapper减少硬编码错误
字段名动态QueryWrapper灵活性强
代码可读性LambdaQueryWrapper直观明了
兼容性QueryWrapper所有场景都适用

建议:在大部分业务场景下,优先使用LambdaQueryWrapper,因为它提供了更好的开发体验和代码安全性。只有在需要动态字段名或处理复杂SQL时,才使用QueryWrapper

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/24 7:09:36

Kamailio 严格路由 vs 松散路由

严格路由比较 $rd 是不是 myself松散路由比较 $route 是不是 myselfrr 模块有 2 个函数&#xff1a;loose_route() 先测试严格路由&#xff0c;如果失败再测试松散路由loose_route_mode(0) 完全等于 loose_route()loose_route_mode(1) 不测试严格路由&#xff0c;只测试松散路由…

作者头像 李华
网站建设 2026/5/23 8:31:30

深度测评8个AI论文网站,助本科生轻松搞定毕业论文!

深度测评8个AI论文网站&#xff0c;助本科生轻松搞定毕业论文&#xff01; AI 工具如何助力论文写作&#xff0c;让毕业不再焦虑 对于大多数本科生来说&#xff0c;撰写毕业论文是一项既重要又充满挑战的任务。从选题到开题&#xff0c;从初稿到修改&#xff0c;每一个环节都可…

作者头像 李华
网站建设 2026/5/21 15:31:49

网络密集性(频繁网络通信)、并发性(支持多用户同时操作)、负载不可预测性(流量波动大)、数据驱动(依赖数据库交互)

一、软件类型及特点Web 应用&#xff08;WebApp&#xff09; 以互联网为核心&#xff0c;用户通过浏览器访问。特点&#xff1a;网络密集性&#xff08;频繁网络通信&#xff09;、并发性&#xff08;支持多用户同时操作&#xff09;、负载不可预测性&#xff08;流量波动大&am…

作者头像 李华
网站建设 2026/5/20 18:58:35

【git】

问题&#xff1a;推送代码提示下面信息&#xff1a;16:22:54.422: [C:\git\yang-teambition] git -c credential.helper -c core.quotepathfalse -c log.showSignaturefalse push --progress --porcelain origin refs/heads/dev_tianzhi:dev_tianzhi ** WARNING: connection is…

作者头像 李华
网站建设 2026/5/20 21:42:18

借助AI技术轻松实现学术范儿的开题报告PPT自动生成方案

AI工具开题报告生成能力对比速览 工具名称 生成速度 内容完整度 参考文献质量 适用场景 AIbiye ⚡⚡⚡⚡ ⭐⭐⭐⭐ 15真实文献 理工科开题 AICheck ⚡⚡⚡ ⭐⭐⭐⭐⭐ 自动匹配领域 人文社科类 秒篇 ⚡⚡⚡⚡⚡ ⭐⭐⭐ 基础文献支持 紧急需求 AskPaper ⚡…

作者头像 李华
网站建设 2026/5/23 11:23:05

如何给AI提问:让机器高效理解你的需求

在人工智能&#xff08;AI&#xff09;快速发展的今天&#xff0c;无论是ChatGPT、Claude、文心一言还是其他大语言模型&#xff0c;提问的质量直接决定了回答的准确性。许多人抱怨AI“答非所问”&#xff0c;其实往往是因为问题本身不够清晰、结构混乱或缺乏关键信息。 本文将…

作者头像 李华