【Mybatis-plus异常】mybatis-plus updateById方法更新不了空字符串和null的解决方法

本文目录

一、背景描述

二、问题原因

三、解决办法

方式一:调整全局的验证策略

方式二:调整字段验证注解

方式三:使用 UpdateWrapper (3.x)

一、背景描述
项目所有技术栈,spring boot (2.1.5.RELEASE) + mybatis-plus (3.3.1.tmp) + 其他。重点是这里使用了 mybatis-plus。

由于享受了懒人福利(不写或者少写sql语句),但是也或多或少的踩了一些别人没有踩到的坑。比如今天在使用 mybatis-plus updateById()方法更新数据库字段时,就遇到了糟心事儿,本来想把某个字段更新为空呢,结果竟然没有更新成功。其他非空字段更新正常。

二、问题原因
至于为什么某个字段更新为空会失败,首先想到的是可能与配置有关。所以去看配置文件,查看关于 mybatis-plus 相关的配置。


看到这个关于 mybatis-plus 配置项目后,有个 global-config 全局配置,field-strategy 字段策略被标注为 NOT_NULL 。然后一下子就明白了是怎么回事。

关于 mybatis-plus 插入或更新的字段有 空字符串 或者 null 时,mybatis-plus 官网上有关于这个问题的解决方案。

在这里,介绍一下 FieldStrategy 有三种策略:

IGNORED:忽略
NOT_NULL:非 NULL,默认策略
NOT_EMPTY:非空
用户有更新字段为 空字符串 或者 null 的需求时,需要对 FieldStrategy 策略进行调整。

以上也是 mybatis-plus 官网上原文。

以下是 com.baomidou.mybatisplus.annotation.FieldStrategy 源码。DEFAULT是默认,这个不用管。

三、解决办法
mybatis-plus 官网上给出了三种解决方法,以下为摘取自 mybatis-plus 官网。想看官网的也可以,官网上的链接地址:https://mp.baomidou.com/guide/faq.html#插入或更新的字段有-空字符串-或者-null

方式一:调整全局的验证策略
注入配置 GlobalConfiguration 属性 fieldStrategy。

具体到我的项目里就是将 field-strategy 属性设备为 IGNORED,即忽略判断策略。

 

这样做是全局性配置,会对所有的字段都忽略判断,如果一些字段不想要修改,但是传值的时候没有传递过来,就会被更新为null,可能会影响其他业务数据的正确性。

方式二:调整字段验证注解

根据具体情况,在需要更新的字段中调整验证注解,如验证非空:
@TableField(strategy=FieldStrategy.NOT_EMPTY)
 具体到我的项目里,是这样的:

我只是在对象里需要更新的字段上添加了 @TableField 注解,使用了更新策略。

使用上述方法,如果需要这样处理的字段较多,那么就需要涉及对各个字段上都添加该注解,显得有些麻烦了。

方式三:使用 UpdateWrapper (3.x)

使用以下方法来进行更新或插入操作:

//updateAllColumnById(entity) // 全部字段更新: 3.0已经移除
mapper.update(
   new User().setName("mp").setAge(3),
   Wrappers.<User>lambdaUpdate()
           .set(User::getEmail, null) //把email设置成null
           .eq(User::getId, 2)
);
//也可以参考下面这种写法
mapper.update(
    null,
    Wrappers.<User>lambdaUpdate()
       .set(User::getAge, 3)
       .set(User::getName, "mp")
       .set(User::getEmail, null) //把email设置成null
       .eq(User::getId, 2)
);

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
问题的原因可能是由于使用了Mybatis-Plus对JSON字段的操作时出现了一些问题。在Mybatis-Plus中,对于JSON字段的操作有几种方式。首先,可以在实体类的字段上使用@TableField注解,并指定typeHandler为FastjsonTypeHandler。这样可以将JSON字符自动转换成对应的Java对象。例如,在Doc实体类中使用了FastjsonTypeHandler对tag字段进行了处理。另外一种方式是在查询时使用Mybatis-Plus提供的自带方法对JSON字段进行处理。可以使用lambda表达式或者QueryWrapper来进行查询,通过指定JSON字段的属性名和属性值来进行查询。如果查询结果为空,可能是因为没有匹配到对应的JSON字段。最后,还可以通过自定义SQL语句来对JSON字段进行操作。可以使用Mybatis-Plus提供的SQL方法,或者编写自定义的SQL来进行操作。如果取出的JSON字符为空,可能是因为数据表中对应的JSON字段没有值或者值为null。需要检查数据表中的数据是否正确。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [mybatis-plus 操作json字段](https://blog.csdn.net/A434534658/article/details/126806270)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [mybatis-plus数据库存JSON字符,java使用实体接收](https://blog.csdn.net/evalsys/article/details/129298067)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值