您的位置:

Java Lambda Query Wrapper:一款高效实用的查询构建工具

一、介绍

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 的扩展功能,令代码维护更加方便,代码可读性也更高。