Bootstrap

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>

;