MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用

假如我们有一张banner_item表,现需要通过banner_id查出所有数据(查询List)

在这里插入图片描述

@Data
public class BannerItem {

    private Long id;

    private String name;

    private String img;

    private String keyword;

    private Integer type;

    private Long bannerId;
}
  • QueryWrapper

最基础的使用方式是这样

// 查询条件构造器
QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.eq("banner_id", id);
// 查询操作
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

然后我们可以引入lambda,避免我们在代码中写类似的于banner_id的硬编码

QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.lambda().eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);
  • LambdaQueryWrapper

为了简化lambda的使用,我们可以改写成LambdaQueryWrapper构造器,语法如下:

LambdaQueryWrapper<BannerItem> wrapper = new QueryWrapper<BannerItem>().lambda();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

我们可以再次将QueryWrapper<BannerItem>.lambda()简化,变成这个样子

LambdaQueryWrapper<BannerItem> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);
  • 链式查询

MyBatis-Plus还提供了一种链式查询的方式,和上面的代码效果一样。
但是这种写法偏向于炫技,可读性没有上面的代码强,大家可以根据需要自行选择方式。

List<BannerItem> bannerItems = new LambdaQueryChainWrapper<>(bannerItemMapper)
                        .eq(BannerItem::getBannerId, id)
                        .list();

如果只想查询一条记录,例如通过id查询某条记录的详情,使用.one()即可,例如

BannerItem bannerItem = new LambdaQueryChainWrapper<>(bannerItemMapper)
                        .eq(BannerItem::getId, id)
                        .one();

 转载:MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用_简单随风的博客-CSDN博客_lambdaquerywrapper

MyBatis-PlusMyBatis的增强工具,其中包括了Wrapper来进行复杂查询。 WrapperMyBatis-Plus提供的一种查询条件构造器,它可以灵活地构造SQL查询条件。Wrapper可以用于构造查询条件、更新条件以及删除条件。 Wrapper使用步骤如下: 1. 创建Wrapper对象 Wrapper对象是用来构造SQL查询条件的对象。在MyBatis-Plus中,有两种Wrapper对象,它们分别是QueryWrapper和UpdateWrapperQueryWrapper用于构造查询条件,UpdateWrapper用于构造更新和删除条件。我们可以使用静态方法创建它们,如下所示: ```java // 创建QueryWrapper QueryWrapper<User> queryWrapper = new QueryWrapper<>(); // 创建UpdateWrapper UpdateWrapper<User> updateWrapper = new UpdateWrapper<>(); ``` 2. 构造SQL查询条件 Wrapper对象提供了一系列的API来构造SQL查询条件,我们可以根据需要来选择使用。 例如,我们可以使用eq方法来构造等于条件: ```java queryWrapper.eq("name", "Tom"); ``` 还可以使用like方法来构造模糊查询条件: ```java queryWrapper.like("name", "Tom"); ``` 除此之外,Wrapper还提供了一些其他的API,例如: - gt:大于条件 - ge:大于等于条件 - lt:小于条件 - le:小于等于条件 - between:范围条件 - in:in条件 - notIn:not in条件 - isNull:为空条件 - isNotNull:不为空条件 - orderBy:排序条件 我们可以根据需要来选择使用。 3. 执行SQL查询操作 构造好查询条件之后,我们需要将Wrapper对象传递给相应的方法来执行SQL查询操作。 例如,我们可以使用selectList方法来查询符合条件的记录: ```java List<User> userList = userMapper.selectList(queryWrapper); ``` 还可以使用update方法来更新符合条件的记录: ```java int result = userMapper.update(user, updateWrapper); ``` 上述就是MyBatis-PlusWrapper的用法。同时,MyBatis-Plus还提供了LambdaQueryWrapperLambdaUpdateWrapper,它们是基于Lambda表达式的Wrapper使用起来更加方便。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值