MyBatis的xml里#{}的参数为null报错、将null作为参数传递报错问题

今天在调试的过程中发现一个bug,把传入的参数写到查询分析器中执行没有问题,但是在程序中执行就报错:org.springframework.jdbc.UncategorizedSQLException : Error setting null parameter. Most JDBC drivers require that the JdbcType must be specified for all nullable parameters. Cause: java.sql.SQLException:无效的列类型

网上找了很久,才找到了错误原因:myBatis的参数,不能传入null(但是在查询分析器中参数为null是允许的),如果传入了null,SQL在类型匹配时找不到匹配的类型,就会报上面的错。

解决办法:

1、在参数后面添加jdbcType=VARCHAR

2、使用if标签

<if test="id != null and id !=''">

and id = #{id}

</if>

3、将null替换成""字符串;

例如:把 insert into user(id,name) values(#{id},#{name})

修改成:insert into user(id,name) values(#{id,jdbcType=VARCHAR},#{name,jdbcType=VARCHAR})

就可以解决这个问题了。

相关推荐
写代码的【黑咖啡】2 分钟前
Python中的Statsmodels:统计建模与假设检验
开发语言·python
沉默-_-4 分钟前
力扣hot100双指针专题解析2(C++)
java·c++·算法·蓝桥杯·双指针
福楠6 分钟前
C++ | 红黑树
c语言·开发语言·数据结构·c++·算法
Jaxson Lin6 分钟前
Java编程进阶:智能仿真无人机项目1.0
java·开发语言
weixin_4331793314 分钟前
python - 函数 function
开发语言·python
sheji341614 分钟前
【开题答辩全过程】以 实验室设备管理系统为例,包含答辩的问题和答案
java
江君是实在人20 分钟前
java 面试题 redis 处理大key问题
java·开发语言·redis
Filotimo_24 分钟前
Spring MVC 注解家族
java
进击的小头32 分钟前
创建型模式:单例模式(C语言实现与实战)
c语言·开发语言·单例模式
禁默35 分钟前
Portainer:让 Docker 管理变简单,用cpolar突破局域网后协作更轻松
java·docker·容器·cpolar