一、介绍
Java Lambda Query Wrapper(简称JLQ),是一款基于MyBatis-Plus的查询构建工具,通过Lambda 表达式,优雅地构建出类型安全的 SQL 查询条件。
JLQ 实现了基本的查询操作,支持多表关联查询,还可以通过 join、groupBy、having、orderBy 等语句实现更多的复杂查询功能。
相较于MyBatis-Plus本身的Wrapper,JLQ的Lambda查询方式更加方便快捷,同时支持与 MyBatis-Plus 的使用相同的操作方式。
二、为什么要使用JLQ
MyBatis-Plus封装了很多的查询条件构建器(Wrapper),但是在使用过程中,需要传入字符串类型的查询条件,容易产生打错字符、类型不对等问题。
而JLQ使用Lambda表达式作为查询条件,避免了构建查询条件时发生的类型错误。
另外,JLQ支持多表关联查询,免去了手写SQL的繁琐,同时在查询操作时也能实现类型安全。
最重要的是,JLQ在性能上比手写的SQL语句具有更高的执行效率。因为JLQ是基于MyBatis-Plus的查询构建器,使用了MyBatis-Plus本身的高效查询逻辑。
三、如何使用JLQ
JLQ的使用方法很简单,只需要在依赖中添加相关的Jar包,然后就可以愉快地使用了。
下面,我们举一个简单的例子来介绍JLQ的基本使用方法:
//实例化查询构建器 LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>(); //设置查询条件 lambdaQueryWrapper.like(User::getUsername,"admin") .ge(User::getAge,18); //执行查询语句 List<User> userList = userMapper.selectList(lambdaQueryWrapper);
上述代码实现了 “查询用户名中包含admin且年龄大于等于18岁的用户” 的动态 SQL 操作,在Lambda表达式中,使用了 User::getUsername 和 User::getAge 来代替了字符串类型的字段名,避免了因为打错字符或者主/副表别名不对而导致的查询失败。
四、JLQ高级用法
如果只是用JLQ来实现基本的查询操作,那么其实用处并不大,而JLQ的高级用法则具有更加强大的功能。
1、多表关联查询
在查询中,经常需要使用多表关联来查出需要的数据,而JLQ则支持非常简单的语法来实现多表关联查询,如下所示:
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>(); lambdaQueryWrapper.table("user") .leftJoin("user_role",UserRole::getUserId, User::getId) .eq(UserRole::getRoleId,roleId); List<User> userList = userMapper.selectList(lambdaQueryWrapper);
通过 table() 方法指定主表名,然后通过 leftJoin() 方法指定关联表和关联条件。查询语句会生成如下的 SQL 语句:
SELECT user.* FROM user LEFT JOIN user_role ON user_role.user_id = user.id WHERE user_role.role_id = ?
2、复杂查询语句
有时候需要查询的条件非常复杂,使用MyBatis-Plus本身提供的 wrapper 无法解决时,可以使用LambdaQueryWrapper代替SQL语句直接构建查询条件。
LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>(); lambdaQueryWrapper.apply(aggregationCondition, null) .eq(User::getEnabled, true); List<User> userList = userMapper.selectList(lambdaQueryWrapper);
上述代码中,apply() 方法实现了一段复杂的查询语句,查询语句会生成如下的 SQL 语句:
SELECT * FROM user WHERE (select count(*) from user_role where user_role.user_id = user.id) > ? AND user.enabled = true
3、通过entity属性查询
使用同一个Entity实现查询操作时,可以通过 entity 属性来进行查询,如下所示:
User user = new User(); user.setUsername("admin"); user.setAge(18); LambdaQueryWrapper<User> lambdaQueryWrapper = new LambdaQueryWrapper<>(user); List<User> userList = userMapper.selectList(lambdaQueryWrapper);
上述代码将一个 User 实例传入 LambdaQueryWrapper 构造器中,JLQ会根据 User 的属性进行查询,生成如下的 SQL 语句:
SELECT * FROM user WHERE username = ? AND age = ?
五、总结
Java Lambda Query Wrapper(JLQ)作为 MyBatis-Plus 的查询构建工具,可以很好地解决在 MyBatis-Plus 中使用 MyBatis Mapper 而经常遇到的查询构建器(Wrapper)类型错误的问题。
同时,JLQ还支持在构建查询条件时使用Lambda表达式,减少了手写 SQL 的繁琐,提高了执行效率。
总体来说,JLQ是一个非常优秀的 MyBatis-Plus 的扩展功能,令代码维护更加方便,代码可读性也更高。