前两个方法实际使用过,后两个方法从其他博客查到的,还没有试验过,暂时记录,以后有机会尝试
问题:MyBatis-Plus 更新字段为null 不生效
在使用mybatis-plus时,发现当前端传入的值为null值时,结果无论怎么操作后端都不执行更新null字段的操作,数据库中的需要被更新为null的字段没有被更新。
原因:
通过sql查看发现null字段未在sql中执行,经过查阅发现mybaits-plus在更新时排除了null字段
MyBatis-Plus对字段的验证策略导致的,MyBatis-Plus默认进⾏了不是全量更新的策略,默认忽略为null 的字段的
解决办法:
1.如果要更新的字段是String类型,
可以把前端传入的null改为空字符串(“”),这样mybati-plus就不会忽略更新该字段
2.使用mybatis-plus的字段注入。
在可能为空的Model类字段上方加@TableField(fill = FieldFill.INSERT_UPDATE),问题解决。
如:
/**
* 介绍说明(非必填)
*/
@TableField(fill = FieldFill.UPDATE)
private String explanation;
共有四种可选,默认不处理
3.修改MyBatis-Plus 全局默认策略
缺点:这样做会对所有的字段都忽略判断,如果一些字段不想要修改,但是传值的时候没有传递过来,就会被更新为null
mybatis-plus:
global-config:
#字段策略 0:"忽略判断",1:"非 NULL 判断",2:"非空判断"
field-strategy: 0
4.修改实体类注解,改变字段的忽略判断
缺点:需要注意数据库字段是否设置为 非null ,如果为非null 也更新不成功
@TableField( updateStrategy = FieldStrategy.IGNORED)
private Date settleTime;
( updateStrategy = FieldStrategy.IGNORED)
private Date settleTime;