当前位置:   article > 正文

【Mybatis-Plus】mybatisplus更新时,实体字段为空,数据库不更新的解决方案_mybatisplus更新字段为空

mybatisplus更新字段为空

一、背景描述

项目技术栈:jdk (1.8) + spring boot (2.1.0) + mybatis-plus (3.5.1)

数据库: MySQL

字段类型:varchar 和 Integer

从前端传过来的数据实体字段, convertType 和 step 设为null时,使用mybatis-plus 的 updateById方法往数据库中更新时,这两个字段不更新,数据不为空可以插入。

二、问题原因

mybatis-plus在更新的时候做了null判断,默认不更新为null的传参。

三、解决方案

有两种方法都可以解决这个问题,都是加注解

3.1 @TableField(fill = FieldFill.UPDATE)
在需要更新的字段上加上 mybatis plus 的注解 @TableField(fill = FieldFill.UPDATE) ,它的作用是字段填充时要更新此字段

    @ApiModelProperty("转换值")
    @TableField(fill = FieldFill.UPDATE)
    private String convertValue;

    @ApiModelProperty("步长")
    @TableField(fill = FieldFill.UPDATE)
    private Integer step;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

3.2 @TableField(updateStrategy = FieldStrategy.IGNORED)
在实体类对应字段上添加上这个注解,它的作用是忽略NULL值的判断

    @ApiModelProperty("转换值")
    @TableField(updateStrategy = FieldStrategy.IGNORED)
    private String convertValue;

    @ApiModelProperty("步长")
    @TableField(updateStrategy = FieldStrategy.IGNORED)
    private Integer step;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/589694
推荐阅读
相关标签
  

闽ICP备14008679号