mybatis plus 之UpdateWrapper操作

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

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

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

UpdateWrapper 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的语句的,如下图:

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

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

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

你可能感兴趣的:(java,mybatis,plus,java)