个人建网站需要多少钱,在线印章生成器,iis 调用wordpress,网络网站制作技巧个人主页#xff1a;金鳞踏雨 个人简介#xff1a;大家好#xff0c;我是金鳞#xff0c;一个初出茅庐的Java小白 目前状况#xff1a;22届普通本科毕业生#xff0c;几经波折了#xff0c;现在任职于一家国内大型知名日化公司#xff0c;从事Java开发工作 我的博客金鳞踏雨 个人简介大家好我是金鳞一个初出茅庐的Java小白 目前状况22届普通本科毕业生几经波折了现在任职于一家国内大型知名日化公司从事Java开发工作 我的博客这里是CSDN是我学习技术总结知识的地方。希望和各位大佬交流共同进步 ~ MyBatisPlus的条件查询构造器
MyBatis-Plus 是一个基于 MyBatis 的增强工具库旨在简化 MyBatis 的使用并提供更多的便利功能。其中QueryWrapper 和 LambdaQueryWrapper 都是 MyBatis-Plus 提供的查询条件构造器用于构建 SQL 查询语句的条件部分。
QueryWrapper
QueryWrapper 是 MyBatis-Plus 最基础的查询条件构造器之一。它通过链式调用的方式构建查询条件并使用普通的字符串作为字段名、操作符和值。它的使用方式类似于传统的 SQL 查询。
LambdaQueryWrapper
LambdaQueryWrapper 是在 QueryWrapper 的基础上增加了使用 Lambda 表达式的功能使得构建查询条件更加类型安全、易读并且能够在编译时进行语法检查。它通过方法引用的方式来指定实体类的属性并提供了丰富的方法来构建查询条件。
类图 Wrapper条件构造抽象类最顶端父类AbstractWrapper用于查询条件封装生成 sql 的 where 条件QueryWrapperEntity 对象封装操作类不是用lambda语法UpdateWrapperUpdate 条件封装用于Entity对象更新操作AbstractLambdaWrapper Lambda 语法使用 Wrapper统一处理解析 lambda 获取 column。LambdaQueryWrapper 用于Lambda语法使用的查询WrapperLambdaUpdateWrapper Lambda 更新封装Wrapper
简单使用
public class User {private Long id;private String name;private Integer age;private LocalDateTime createTime;// 其他字段...// 省略 getter 和 setter 方法
}QueryWrapperUser queryWrapper new QueryWrapper();
queryWrapper.eq(age, 25).like(name, John).orderByDesc(create_time).last(limit 10);
ListUser userList userMapper.selectList(queryWrapper);LambdaQueryWrapperUser lambdaQueryWrapper new LambdaQueryWrapper();
lambdaQueryWrapper.eq(User::getAge, 25).like(User::getName, John).orderByDesc(User::getCreateTime).last(limit 10);
ListUser userList userMapper.selectList(lambdaQueryWrapper);我们首先构建了 QueryWrapper 或 LambdaQueryWrapper 对象并设置查询条件。然后创建了一个 Page 对象来指定要查询的页码和每页数量。最后通过调用映射器接口的 selectPage() 方法来执行分页查询得到分页后的结果。
注意selectPage() 方法返回的是一个 Page对象其中包含了分页后的数据和总记录数等信息。
如果你希望在构建查询条件时具有更好的类型安全性和易读性推荐使用 LambdaQueryWrapper 。如果简单查询条件已经满足需求或者需要更灵活的拼接查询条件可以使用 QueryWrapper 。 注意lambdaQueryWrapper.eq(User::getAge, 25) 里面的 User::getAge 表示查询 age 值为25的用户。这是一种 Java 8 中的语法用于方法引用直接引用了实体类的属性和方法。 优缺点
LambdaQueryWrapper
优点类型安全、易读性高可以直接使用实体类的属性和方法。缺点在某些复杂查询操作下可能不支持。
QueryWrapper
优点更灵活支持复杂查询操作和 SQL 片段拼接。缺点类型不安全、可读性较差。
一般情况下如果你的查询条件相对简单且你更注重代码的清晰性和类型安全性可以优先考虑使用 LambdaQueryWrapper。但如果你需要进行复杂的查询操作特别是涉及到复杂的 SQL 片段拼接等情况可能需要使用 QueryWrapper。 文章到这里就结束了如果有什么疑问的地方可以在评论区指出~ 希望能和大佬们一起努力诸君顶峰相见 再次感谢各位小伙伴儿们的支持