当前位置:   article > 正文

解决mybatis-plus修改对象属性为null或““失效 两种方法_mybatis修改函数属性为空

mybatis修改函数属性为空

ignored 不管有没有有设置属性,所有的字段都会设置到insert语句中,如果没设置值,全为null,这种在update 操作中会有风险,把有值的更新为null

not_null,也是默认策略,也就是忽略null的字段,不忽略""

not-empty 为null,为空串的忽略,就是如果设置值为null,“”,不会插入数据

配置文件

mybatis-plus:
  mapper-locations: classpath*:sql/**/*Mapper.xml
  configuration.log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      logic-not-delete-value: 0
      logic-delete-value: 1
      update-strategy: not_empty
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

在这里插入图片描述

@TableField(updateStrategy = FieldStrategy.IGNORED)
  • 1

在这里插入图片描述
因为附件可以修改为空值,所以加@TableField(updateStrategy = FieldStrategy.IGNORED)注解,可以让poaAtt为空的时候用update更新数据库是不会忽略此字段。
后来我在修改该对象其他属性时,没有设置该poaAtt的值,更新时发现poaAtt就被更新为空。所以为了避免此情况我不得重新查询该字段值再赋值一遍。
切记用此注解需谨慎!!!

第二种方法
首先场景是数据持久层使用的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);
  • 1
  • 2
  • 3
  • 4

  • 1
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号