LambdaQueryWrapper 是 MyBatis-Plus 提供的一个强大的条件构造器,它主要用于构建 SQL 语句中的 WHERE 条件部分。与传统的字符串拼接或 XML 映射相比,LambdaQueryWrapper 通过 Java 的 Lambda 表达式来构建条件,这种方式不仅提高了代码的可读性和可维护性,还避免了 SQL 注入的风险。
下面将详细介绍 LambdaQueryWrapper 的使用方式。
- 引入 MyBatis-Plus 依赖
- 使用 LambdaQueryWrapper
假设你有一个用户表 user,对应的实体类为 User,其中包含字段 id、name、age 等。
2.1 创建 LambdaQueryWrapper 实例
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
2.2 添加查询条件
你可以通过链式调用的方式添加多个查询条件。
单一条件
queryWrapper.eq(User::getName, "张三"); // 等于
queryWrapper.ne(User::getAge, 18); // 不等于
queryWrapper.gt(User::getAge, 18); // 大于
queryWrapper.ge(User::getAge, 18); // 大于等于
queryWrapper.lt(User::getAge, 30); // 小于
queryWrapper.le(User::getAge, 30); // 小于等于
queryWrapper.like(User::getName, "三"); // LIKE '%三%'
queryWrapper.notLike(User::getName, "三"); // NOT LIKE '%三%'
复合条件
queryWrapper.and(wrapper -> wrapper.eq(User::getName, "张三").gt(User::getAge, 18));
queryWrapper.or(wrapper -> wrapper.eq(User::getName, "李四").lt(User::getAge, 20));
2.3 使用 LambdaQueryWrapper 进行查询
假设你使用的是 MyBatis-Plus 提供的 BaseMapper 接口,你可以这样使用 LambdaQueryWrapper 进行查询:
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
@Autowired
private UserMapper userMapper; // 假设你的 Mapper 接口继承自 BaseMapper<User>
public List<User> selectUsers() {
LambdaQueryWrapper<User> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(User::getName, "张三").gt(User::getAge, 18);
return userMapper.selectList(queryWrapper);
}
- 小结
LambdaQueryWrapper 通过 Lambda 表达式的方式,使得 SQL 条件的构建更加直观和类型安全。它大大简化了 MyBatis-Plus 中的条件查询操作,使得代码更加简洁、易于理解和维护。在实际的开发中,推荐多使用 LambdaQueryWrapper 来构建查询条件。