使用Mybatis-plus更新null字段的问题分析及解决过程

 更新时间:2026年05月08日 09:15:10   作者:十步杀一人_千里不留行  
文章主要讲述了在使用MybatisPlus对Oracle数据库的某个字段进行set为Null操作时遇到的问题及解决方案,尝试了全局配置和在字段上加注解等方法均未解决问题,最终通过在el表达式中指定javaType解决了问题

一、起因

业务需要对Oracle数据库的某个字段进行set为Null的操作。

网上找了很多帖子,不外乎那么几种解决办法,但都讲的不完全对,而且对我的场景不适用,大白话就是没用!

二、网上的解决方案,我这里不适用

1.全局配置:这种方案不考虑,因为只有这个表的这个字段需要更新为null,其他的表字段不需要更新null

2.在要更新为null的字段上加上注解 strategy = FieldStrategy.IGNORED。

这个值默认是要进行非空检查的,来看源码:

//字段策略枚举类
public enum FieldStrategy {
    IGNORED(0, "忽略判断"),
    NOT_NULL(1, "非 NULL 判断"),
    NOT_EMPTY(2, "非空判断");
    //省略部分代码
}

我们要的效果是此处忽略非空检查,所以应该如下配置:

@TableField(value = "BIRTHDAY",strategy = FieldStrategy.IGNORED)
private Date birthday;

这里要说一句,其实全局配置也是更改这个默认值,但你改了全局,你觉得行吗?不行滴,小兄弟!!!

重点来了,网上的教程都是到这里就OK了,但不好意思,我的配置了之后依然报错。不行啊,大兄弟!!!

三、真正的解决之道,完美

配置了上面的选项后,依然报错,提示javaType的类型是other,看了一下源码,果然javaType的默认值是other。

接下来重点又来了,对于如何配置javaType,网上的解决方案是自己写sql语句,在sql里面指定javaType,如下所示:

<insert id="save" parameterType="com.tarena.entity.Cost">
  insert into cost values(
      cost_seq.nextval,
      #{name,jdbcType=VARCHAR},
      #{base_duration,jdbcType=INTEGER},
      #{base_cost,jdbcType=DOUBLE}
  )
</insert>

这种方案我没尝试,应该是可以的。但是,但是,但是,我们为什么要用Mybatis Plus吗,大家想想,不就是为了不写SQL吗,如果要写SQL我还废什么话,写SQL他也不会给我报上面的错误。所以,任性,我就是不想写SQL,那么,下面就是终极解决方案。

Mybatis Plus支持通过el表达式指定javaType。先来看下源码怎么说的,源码里面说的很清楚了。

    /**
     * <p>
     * 当该Field为类对象时, 可使用#{对象.属性}来映射到数据表.
     * </p>
     * <p>
     * 支持:@TableField(el = "role, jdbcType=BIGINT)<br>
     * 支持:@TableField(el = "role, typeHandler=com.baomidou.springcloud.typehandler.PhoneTypeHandler")
     * </p>
     */
    String el() default "";

还是不知道怎么用?

看最终的配置方式1

    /** 检验结果单位(码值:lab_result_unit)*/
	@TableField(value="lab_result_unit",strategy = FieldStrategy.IGNORED,el = "labResultUnit,jdbcType=DECIMAL")
	private Integer labResultUnit;

最终配置方式2

修改application.yml:

mybatis-plus:
  configuration:
    jdbc-type-for-null: 'null' #注意:单引号

网上很多文章都针对自己的场景能解决问题,但真的还是具体问题需要具体分析,最终才能找到适合自己问题的解决之道。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MyBatis Generator生成代码及使用方式详解

    MyBatis Generator生成代码及使用方式详解

    这篇文章主要介绍了MyBatis Generator生成代码及使用方式的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • 关于Synchronized和ReentranLock的区别及说明

    关于Synchronized和ReentranLock的区别及说明

    文章介绍了Java中的`synchronized`关键字和`ReentrantLock`类,两者都可以用于解决多线程同步问题,但`ReentrantLock`提供了更多的功能和灵活性
    2024-12-12
  • SpringBoot启动时如何修改上下文

    SpringBoot启动时如何修改上下文

    本文介绍了如何在Spring Boot启动时修改上下文,以便加载封装JAR中的国际化文件,通过在resources目录下的META-INF文件夹中的spring.factories文件中配置指定类,可以实现这一功能
    2024-11-11
  • gson ajax 数字精度丢失问题的解决方法

    gson ajax 数字精度丢失问题的解决方法

    下面小编就为大家带来一篇gson ajax 数字精度丢失问题的解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • springcloud中Feign超时提示Read timed out executing POST的问题及解决方法

    springcloud中Feign超时提示Read timed out executing

    Feign接口调用分两层,Ribbon的调用和Hystrix调用,理论上设置Ribbon的时间即可,但是Ribbon的超时时间和Hystrix的超时时间需要结合起来,这篇文章给大家介绍springcloud之Feign超时提示Read timed out executing POST问题及解决方法,感兴趣的朋友一起看看吧
    2024-01-01
  • idea如何自动生成serialVersionUID

    idea如何自动生成serialVersionUID

    这篇文章主要介绍了idea如何自动生成serialVersionUID,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Spring Boot Starter中Bean 注册与属性绑定的两大机制最佳实践方案

    Spring Boot Starter中Bean 注册与属性绑定的两大机制最佳实践方案

    在 Spring Boot的世界里,Starter(启动器)是简化依赖管理和自动化配置的强大工具,本文将深入探讨 Spring Boot Starter 中 Bean 初始化的核心机制,并指出最佳实践,感兴趣的朋友跟随小编一起看看吧
    2025-10-10
  • SpringBoot 中html的页面间跳转问题小结

    SpringBoot 中html的页面间跳转问题小结

    这篇文章主要介绍了SpringBoot 中html的页面间跳转问题小结,本文给大家分享两种方法,结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • Spring Data Jpa 复杂查询方式总结(多表关联及自定义分页)

    Spring Data Jpa 复杂查询方式总结(多表关联及自定义分页)

    这篇文章主要介绍了Spring Data Jpa 复杂查询方式总结(多表关联及自定义分页),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 基于SpringBoot和MongoDB实现实时分析和日志处理功能

    基于SpringBoot和MongoDB实现实时分析和日志处理功能

    实时分析和日志处理在现代应用程序开发中扮演着重要的角色,MongoDB是一个非常流行的NoSQL数据库,其高性能和灵活性使其成为实时分析和日志处理的理想选择,本文将介绍如何使用 Spring Boot 和 MongoDB 实现实时分析和日志处理的功能
    2023-06-06

最新评论