一、背景描述
项目技术栈: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) ,它的作用是字段填充时要更新此字段文章来源:https://www.toymoban.com/news/detail-792716.html
@ApiModelProperty("转换值")
@TableField(fill = FieldFill.UPDATE)
private String convertValue;
@ApiModelProperty("步长")
@TableField(fill = FieldFill.UPDATE)
private Integer step;
3.2 @TableField(updateStrategy = FieldStrategy.IGNORED)
在实体类对应字段上添加上这个注解,它的作用是忽略NULL值的判断文章来源地址https://www.toymoban.com/news/detail-792716.html
@ApiModelProperty("转换值")
@TableField(updateStrategy = FieldStrategy.IGNORED)
private String convertValue;
@ApiModelProperty("步长")
@TableField(updateStrategy = FieldStrategy.IGNORED)
private Integer step;
到了这里,关于【Mybatis-Plus】mybatisplus更新时,实体字段为空,数据库不更新的解决方案的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!