Mybatis-plus更新字段为null两种常用方法及优化
前言
更新时,把某些字段的值更新为null,但是目前mybatis-plus的update/updateById会忽略实体类中为null的字段,导致这些字段没有更新还是原来的值。
网上比较常用的有两种:
1、在实体类的属性上增加注解:@TableField(updateStrategy = FieldStrategy.IGNORED)
/** * 手机号 **/ @TableField(updateStrategy = FieldStrategy.IGNORED) private String phone;
缺点:当在其它接口更新别的字段时,本来没有想更新这个字段,但是也会把这个字段更新为null。
2、使用LambdaUpdateWrapper的set更新
// set更新 LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate(); updateWrapper.set(UserEntity::getPhone, null); updateWrapper.eq(UserEntity::getUserId, "0001"); userMapper.update(null, updateWrapper);
缺点:需要一个一个属性set,比较麻烦。我平常使用的都是从DTO直接copy到Entity里面,要是updateWrapper.set的话比较繁琐,而且有的值为null时不更新。
优化:
还是使用LambdaUpdateWrapper的set更新,方法update(entity, updateWrapper)当第一个参数实体类entity不为null时,其中entity中为null的属性不会更新,不为null的会更新, updateWrapper.set()是不论是否为null都更新。
既可以携程:
LambdaUpdateWrapper<UserEntity> updateWrapper = Wrappers.lambdaUpdate(); if (StringUtils.isEmpty(phone)) { // 这个值为null,才set,不然sql里面会两次赋值,执行sql时报错 updateWrapper.set(UserEntity::getPhone, null); } updateWrapper.eq(UserEntity::getUserId, "0001"); UserEntity entity = new UserEntity(); entity.setName("张三"); entity.setAge(null); userMapper.update(null, updateWrapper);
说明:根据userId更新,name为张三,phone为null,而age不更新。
SQL:
update user set name = '张三', phone = null where user_id = '0001'
结论:使用update(entity, updateWrapper)更新
属性为null不更新,使用entity保存;若属性为null时更新表中字段为null,则用updateWrapper.set()保存数据,set前需要判断这个属性的值为null。
总结
到此这篇关于Mybatis-plus更新字段为null两种常用方法及优化的文章就介绍到这了,更多相关Mybatis-plus更新字段为null内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解spring cloud如何使用spring-test进行单元测试
这篇文章主要介绍了spring cloud如何使用spring-test进行单元测试,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-11-11解决logback-classic 使用testCompile的打包问题
这篇文章主要介绍了解决logback-classic 使用testCompile的打包问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-07-07Eclipse配置tomcat发布路径的问题wtpwebapps解决办法
这篇文章主要介绍了Eclipse配置tomcat发布路径的问题wtpwebapps解决办法的相关资料,需要的朋友可以参考下2017-06-06
最新评论