mybatis plus 之UpdateWrapper操作

目前java开发的系统为了可移植性更高,都采用了mybatis plus来做持久层,现在介绍一下其中UpdateWrapper的用法:

UpdateWrapper<TemplateDetailsEntity> wrapper = Wrappers.update();
            wrapper.lambda()
                    .set(TemplateDetailsEntity::getPriority, "")
                    .eq(TemplateDetailsEntity::getSortCode, entity.getSortCode());
            update(null, wrapper);

如上述代码,可以直接在 .lambda() 之后设置set 的内容,以及添加查询的条件。

UpdateWrapper<TemplateDetailsEntity> updateWrapper = Wrappers.update();
        updateWrapper.lambda()
                .in(TemplateDetailsEntity::getId,ids)
                .eq(TemplateDetailsEntity::getStatus,oldStatus);
        TemplateDetailsEntity entity = new TemplateDetailsEntity();
        entity.setStatus(newStatus);
        entity.setUpdateTime(new Date());
        return update(entity, updateWrapper);

上述方法是先在UpdateWrapper中设置查询条件,再通过实体类去设置要修改的值,也就是sql语句中的set内容,这种是比较符合mybatis plus的语句的,如下图:

 源码的方法的实现中就是支持实体传参的。

如果修改的值比较多时,推荐用第二种方式;如果修改的值较少时,则推荐第一种方式。

希望能对大家的开发有所帮助,我是空谷有来人,谢谢支持。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值