LambdaQueryWrapper基本使用

LambdaQueryWrapper 是 MyBatis-Plus 提供的一个强大的条件构造器,它主要用于构建 SQL 语句中的 WHERE 条件部分。与传统的字符串拼接或 XML 映射相比,LambdaQueryWrapper 通过 Java 的 Lambda 表达式来构建条件,这种方式不仅提高了代码的可读性和可维护性,还避免了 SQL 注入的风险。

下面将详细介绍 LambdaQueryWrapper 的使用方式。

  1. 引入 MyBatis-Plus 依赖
  2. 使用 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);
}
  1. 小结

LambdaQueryWrapper 通过 Lambda 表达式的方式,使得 SQL 条件的构建更加直观和类型安全。它大大简化了 MyBatis-Plus 中的条件查询操作,使得代码更加简洁、易于理解和维护。在实际的开发中,推荐多使用 LambdaQueryWrapper 来构建查询条件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值