目前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的语句的,如下图:
?源码的方法的实现中就是支持实体传参的。
如果修改的值比较多时,推荐用第二种方式;如果修改的值较少时,则推荐第一种方式。
希望能对大家的开发有所帮助,我是空谷有来人,谢谢支持。
|