Mybatis Plus更新时字段(属性)为null或空字符串的问题

当程序中使用Mybatis Plus执行更新操作时,如果要使用Mybatis Plus自带的更新操作(非sql、wapper)

例如userService.updateById(user);如果user中的某个属性为null或空字符串时,Mybatis Plus是不会对其进行更新操作的,如果有需求即使为null或空字符串时也更新则可以使用以下几种方法:

  1. 添加注解

    @TableField(value = "name", updateStrategy=FieldStrategy.IGNORED)
    private String name;
    

    FieldStrategy 是 MyBatis-Plus 框架中的一个枚举类,用于定义字段更新策略。
    (注解只对更新操作生效,对插入操作不生效。)
    该枚举类包含以下几个常量:
    IGNORED:意思是"忽略判断",所有值都更新和插入。
    NOT_NULL:当字段为 null 时不进行更新。
    NOT_EMPTY:当字段为 null 或空字符串时不进行更新。
    DEFAULT:使用数据库默认值进行更新。
    NEVER:永远不更新字段的值。

  2. 全局配置

    mybatis-plus.global-config.db-config.update-strategy=ignored 是 MyBatis-Plus 的全局配置属性,用于设置全局的更新策略。在 MyBatis-Plus 中,可以通过全局配置来设置一些共享的属性和行为。其中,db-config 是一个子属性,可以用于配置数据库相关的属性,比如 update-strategyupdate-strategy 属性可以设置默认的更新策略。ignored 表示所有值都更新和插入,要在应用中使用该全局配置,需要在 MyBatis-Plus 的配置文件(通常为 application.ymlapplication.properties)中添加以下配置:

    mybatis-plus:
      global-config:
        db-config:
          update-strategy: ignored #如果配置其他操作还有insert-strategy、select-strategy等
    

    这样,在整个应用程序中,所有值都更新和插入

    需要注意的是,全局配置对应用程序中所有的实体类都生效,如果某些实体类需要自定义不同的更新策略,可以在实体类上直接使用,@TableField 注解,并设置不同的 updateStrategy 属性。这样,实体类级别的配会覆盖全局的配置。

  3. 使用条件构造器的set进行赋值

    UpdateWrapper<User> updateWrapper = Wrappers.update();
    updateWrapper.set("name", null);
    updateWrapper.eq("id", 5);
    boolean update = userService.update(updateWrapper);
    
  4. 在mapper.xml中写对应的sql语句

问题的原因可能是由于使用了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 ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值