条件构造器用法
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>