我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mybatis中Oracle参数为NULL错误问题及解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mybatis中Oracle参数为NULL错误问题及解决

mybatis中Oracle参数为NULL错误问题

在Mybatis操作Oracle数据库的时候( PS:mysql中不会出现),会遇到个小问题,

当数据库为Oracle时候,插入某个参数数据如果为null,mybatis会报错,提示类型不正确,

原因是当插入数据为null类型的时候,mybatis会自动转换为JdbcType.OTHER类型,因此需要修改一下参数的转换类型

有两种方式可以解决:

1.公共配置方法

在Mybatis配置中设置jdbcTypeForNull=NULL,

即:

<settings>
   <setting name="jdbcTypeForNull" value="NULL"/>
</settings>

2.参数配置方法

修改mybatis的sql语句参数通配符,设置当参数为null时候采用 JdbcType.NULL类型

即:

select * from tb where name = #{name,jdbcType=NULL}

如上两种方式配置,都可以解决Oracle下参数为null操作错误问题!

mybatis oracle insert 属性为null保存报错 无效的列类型1111

mybatis   数据库 oracle  insert 时有些备用字段为空,保存报错,无效的列类型:1111

解决办法

1、修改配置文件 application.yml  增加配置 jdbc-type-for-null: 'null' ,单引号不要忘了

mybatis:
  mapper-locations: classpath:mapping/*/*.xml
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    call-setters-on-nulls: true
    jdbc-type-for-null: 'null'

2、在SQL语句里相应的属性上带上JDBCType

3、增加配置类

查看mp-starter-源码, MybatisPlusAutoConfiguration, 可以发现,第119行有一个configurationCustomizers,可以修改configuration  自定义一个,配上就完工

@Bean
    public ConfigurationCustomizer configurationCustomizer(){
        return new MybatisPlusCustomizers();
    }
 
    class MybatisPlusCustomizers implements ConfigurationCustomizer {
 
        @Override
        public void customize(org.apache.ibatis.session.Configuration configuration) {
            configuration.setJdbcTypeForNull(JdbcType.NULL);
        }

4、

第一步:把 可更新为空的 javabean 属性前加上注解:

@TableField(el = "username, jdbcType=VARCHAR")
@Email
@TableField(el = "email, jdbcType=VARCHAR")
private String email;

第二步: 使用updateAllColumnById方法,而不是updateById.    如:

this.baseMapper.updateAllColumnById(user); 

报错原因:

postgreSQL,MySQL,SQLSERVER都支持JdbcType.NULL类型,Oracle是不支持,适配的时候也因为这个问题导致mybatis报错。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mybatis中Oracle参数为NULL错误问题及解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mybatis中Oracle参数为NULL错误问题及解决

这篇文章主要介绍了mybatis中Oracle参数为NULL错误问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-22

如何解决MyBatis中Enum字段参数解析问题

小编给大家分享一下如何解决MyBatis中Enum字段参数解析问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!基础Class和TypeHandlerMyBati
2023-06-20

阿里云服务器配置参数错误问及解决方法

在使用阿里云服务器时,有时会遇到配置参数错误的问题。这些问题可能导致服务器无法正常运行,给用户带来不必要的困扰。本文将介绍一些常见的阿里云服务器配置参数错误及其解决方法,帮助用户快速解决问题。1.IP地址配置错误IP地址是服务器与外界通信的关键参数之一,如果IP地址配置错误,服务器将无法正常连接到互联网。常见的I
阿里云服务器配置参数错误问及解决方法
2024-01-16

mysql中查询字段为null的数据navicat问题怎么解决

这篇“mysql中查询字段为null的数据navicat问题怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mysql
2023-07-04

mybatis中@Param注解总是报取不到参数问题如何解决

这篇文章主要介绍“mybatis中@Param注解总是报取不到参数问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mybatis中@Param注解总是报取不到参数问题如何解决”文章能帮助大
2023-07-02

如何解决springboot mybatis调用多个数据源引发的错误问题

这篇文章给大家分享的是有关如何解决springboot mybatis调用多个数据源引发的错误问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。springboot mybatis调用多个数据源错误报错org.s
2023-06-26

解决springmvc关于前台日期作为实体类对象参数类型转换错误的问题

页面报错:后台错误:Field error in object 'user' on field 'birthday': rejected value [2013-06-24]; codes [typeMismatch.user.birthd
2023-05-31

golang函数的错误处理的常见问题及其解决方案

在 golang 中,错误处理是一项重要任务,需注意以下常见问题及解决方案:忽略错误:始终检查函数调用的错误值,并根据需要采取适当措施。不一致的错误处理:确保函数签名和文档明确说明返回错误的情况,并强制调用者检查错误。未处理的错误:在 ma
golang函数的错误处理的常见问题及其解决方案
2024-04-24

如何解决php中date函数格式化错误的问题

这篇文章将为大家详细讲解有关如何解决php中date函数格式化错误的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php date函数格式化错误的解决办法:1、修改php.ini配置文件;2、加上“d
2023-06-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录