首先场景是数据持久层使用的mybatis-plus,只需要修改对象的几个字段且字段都需要进行判断是否需要赋值为null,然后进行修改使用的是updateById(),结果发现赋值为null的字段不生效;
去百度了一波说用updateStrategy = FieldStrategy.IGNORED,然后在实体类对应属性添加了updateStrategy = FieldStrategy.IGNORED,再执行了一波,发现需要设置为null的字段确实生效了,但是没有需要修改的字段也被修改为了null,这是个巨坑;
最后发现还是Wrappers.lambdaUpdate()能解决问题
LambdaUpdateWrapper<UrlTablePo> objectLambdaUpdateWrapper = Wrappers.lambdaUpdate();
objectLambdaUpdateWrapper.eq(UrlTablePo::getId, 20);
objectLambdaUpdateWrapper.set(UrlTablePo::getShortUrl, null);
mapper.update(null, objectLambdaUpdateWrapper);
这样就成功了
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/5297.html