mybatisPlus的wrapper用法

条件构造器用法

QueryWrapper和LambdaQueryWrapper通常用来构建select,delete,update的where条件部分

updateWrapper和LambdaUpdateWrapper通常只有在set语句比较特殊才使用

尽量使用LambdaQueryWrapper和LambdaUpdateWrapper,避免硬编码

有些时候我们在使用wrapper的时候,需要在service里编写sql代码,这是在一些项目规范里不允许的

@Test
    void testupdateWrapper(){
        List<Long> ids=List.of(1L,2L,3L);
        UpdateWrapper<User> userUpdateWrapper = new UpdateWrapper<User>()
                .setSql("money=money-200")
                .in("id",ids);
        userMapper.update(null,userUpdateWrapper);
    }

所以我们需要利用mybatisplus中的wrapper来构建复杂的where条件,然后自己定义sql语句中剩下的部分 

 1 基于wrapper构建where条件

@Test
void testupdateWrapper(){
List<Long> ids=List.of(1L,2L,3L);

int amount =200
LambdaQueryWrapper<User> wrapper = new LambdaqueryWrapper<User>()
.in(User::getId,ids);
userMapper.updateMoneyByIds(wrapper,amount);
}

2 在mapper方法参数中用Param注解声明wrapper变量名称,必须是ew

void updateBalanceByIds(@Param(Constants.WRAPPER) QueryWrapper<User> wrapper,@Param("amount") int amount);

: 注(这里使用了Constants.WRAPPER来代替ew)

3自定义sql,并使用wrapper条件 ,${ew.customSqlSegment} 不可缺少

<update id="updateBalanceByIds">
update user set balance=money-#{amount} ${ew.customSqlSegment}
</update>

  • 14
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值