LambdaQueryWrapper与QueryWrapper的使用

一、LambdaQueryWrapper、QueryWrapper是什么?

LambdaQueryWrapper与QueryWrapper是Mybatis-plus中的条件构造器

二、如何使用条件构造器

我们需要先引入Mybatis-plus框架,你可以在pom.xml文件中添加依赖

LambdaQueryWrapper的使用方法

LambdaQueryWrapper可以使用lambda表达式构建SQL查询语句,这让我们可以在不使用繁琐的SQL语句的情况下快速地进行数据库操作。

首先,我们需要在实体类中注解@Table和@Id,以指定表名和主键: 

@Data
@TableName("user")
public class UserEntity {

    @TableId(type = IdType.AUTO)
    private Long id;

    private String name;

    private Integer age;

}

接下来,我们可以使用LambdaQueryWrapper来进行查询操作。例如,我们希望查询年龄大于18岁且姓名为“张三”的用户信息:

LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
        .eq(UserEntity::getName, "张三") // 姓名 = 张三
        .gt(UserEntity::getAge, 18); // 年龄 > 18

List<UserEntity> userList = userMapper.selectList(qw);


以上代码使用了LambdaQueryWrapper的eq和gt方法,它们分别表示等于和大于操作。

以下是LambdaQueryWrapper常用的方法:

QueryWrapper的使用方法

QueryWrapper是Mybatis-plus 3.0.7版本之前推出的查询工具类。和LambdaQueryWrapper的使用方法不同,QueryWrapper需要使用SQL语句来构建查询条件。

如果你使用的是Mybatis-plus 3.0.7版本以前的版本,那么你需要使用QueryWrapper。

使用QueryWrapper进行查询操作的代码示例:

QueryWrapper<UserEntity> qw = new QueryWrapper<UserEntity>()
        .eq("name", "张三") // 姓名 = 张三
        .gt("age", 18); // 年龄 > 18

List<UserEntity> userList = userMapper.selectList(qw);


以上代码使用了QueryWrapper的eq和gt方法,它们分别表示等于和大于操作。

以下是QueryWrapper常用的方法:

三、实际应用

实践应用,在实际应用中,LambdaQueryWrapper和QueryWrapper常常被用于复杂的查询操作,甚至可以用于分页查询。

分页查询

例如,我们可以使用LambdaQueryWrapper来实现带分页的查询操作:

IPage<UserEntity> page = new Page<>(1, 10); // 分页查询
LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
        .eq(UserEntity::getName, "张三") // 姓名 = 张三
        .gt(UserEntity::getAge, 18); // 年龄 > 18

IPage<UserEntity> userPage = userMapper.selectPage(page, qw);

System.out.println(userPage.getRecords()); // 输出查询结果

动态查询

在实际应用中,我们还可以使用LambdaQueryWrapper和QueryWrapper实现更多复杂的查询操作,以满足不同的业务需求。例如,我们可以使用LambdaQueryWrapper和QueryWrapper进行动态查询,通过判断前端传入的参数,来组合SQL语句,实现灵活的查询操作。

以下是代码示例:

public List<UserEntity> getUserList(String name, Integer age) {
    LambdaQueryWrapper<UserEntity> qw = new LambdaQueryWrapper<UserEntity>()
            .eq(StringUtils.isNotEmpty(name), UserEntity::getName, name) // 姓名 = name
            .gt(age != null, UserEntity::getAge, age); // 年龄 > age

    return userMapper.selectList(qw);
}


以上代码中,我们通过LambdaQueryWrapper实现了动态的查询操作。如果传入的name参数不为空,那么就会添加一个等于查询条件;如果传入的age参数不为空,那么就会添加一个大于查询条件。

这样的查询操作,可以根据前端传入的参数,灵活地组合SQL语句,实现更多的业务需求。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值