MyBatis-Plus updateById方法更新不了空字符串null解决方法

1 问题

在用mybatis-plus封装的updateById方法来更新数据时,想把一个字段设置为null值,但是发现更新后数据没有为null还是原来的值,这是因为mybatis-plus在更新的时候做了null判断,默认不更新为null的传参。

 

2 解决方法

在实体类对应的字段上加注解@TableField(strategy=FieldStrategy.IGNORED),忽略null值的判断,例如

/**
 * 经营许可证编号
 */
@TableField(strategy = FieldStrategy.IGNORED)
private String businessLicenseNo;

当@TableField注解有多个值时

/**
 * 经营许可证编号
 */
@TableField(value = "business_license_no", strategy = FieldStrategy.IGNORED)
private String businessLicenseNo;
问题的原因可能是由于使用了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 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值