解决方案
在指定了jdbcType的前提下, 在mybatis-config.xml文件中配置一下,添加settings配置,NULL要大写,如下:
<settings>
<!--插入为空时插入空值避免报空指针-->
<setting name=“jdbcTypeForNull” value=“NULL”/>
<settings>
如果是mybatis plus的话,在.yml里可以这样写:
mybatis-plus:
configuration:
jdbc-type-for-null: 'null'
也可以修改配置文件类,很多种方式,其实都是把jdbcTypeForNull设为null,是不是批量操作都可以这么设
产生的原因
设置的JDBC类型为空时,某些驱动程序要指定值,默认是OTHER并不是BULL,mybatis此时是无法处理null值的
记一下mybatis常见配置设置
<!– 配置设置 –>
<settings>
<!– 配置全局性 cache 的 ( 开 / 关) default:true –>
<setting name=“cacheEnabled” value=“true”/>
<!– 是否使用 懒加载 关联对象 同 hibernate中的延迟加载 一样 default:true –>
<setting name=“lazyLoadingEnabled” value=“true”/>
<!– [当对象使用延迟加载时 属性的加载取决于能被引用到的那些延迟属性,否则,按需加载(需要的是时候才去加载)] –>
<setting name=“aggressiveLazyLoading” value=“true”/>
<!– 是否允许单条sql 返回多个数据集 (取决于驱动的兼容性) default:true –>
<setting name=“multipleResultSetsEnabled” value=“true”/>
<!– 是否可以使用列的别名 (取决于驱动的兼容性) default:true–>
<setting name=“useColumnLabel” value=“true”/>
<!–允许JDBC 生成主键。需要驱动器支持。如果设为了true,这个设置将强制使用被生成的主键,有一些驱动器不兼容不过仍然可以执行。 default:false–>
<setting name=“useGeneratedKeys” value=“false”/>
<!–指定 MyBatis 如何自动映射 数据基表的列 NONE:不隐射 PARTIAL:部分 FULL:全部–>
<setting name=“autoMappingBehavior” value=“PARTIAL”/>
<!– 这是默认的执行类型
SIMPLE :简单
REUSE:执行器可能重复使用prepared statements 语句
BATCH:执行器可以重复执行语句和批量更新
–>
<setting name=“defaultExecutorType” value=“SIMPLE”/>
<!– 设置驱动等待数据响应的超时数 默认没有设置–>
<setting name=“defaultStatementTimeout” value=“25000″/>
<!– [是否启用 行内嵌套语句 defaut:false] –>
<setting name=“safeRowBoundsEnabled” value=“false”/>
<!– [是否 启用 数据中 A_column 自动映射 到 java类中驼峰命名的属性 default:fasle] –>
<setting name=“mapUnderscoreToCamelCase” value=“false”/>
<!– 设置本地缓存范围 session:就会有数据的共享 statement:语句范围 (这样就不会有数据的共享 ) defalut:session –>
<setting name=“localCacheScope” value=“SESSION”/>
<!– 设置但JDBC类型为空时,某些驱动程序要指定值,default:OTHER –>
<setting name=“jdbcTypeForNull” value=“DEFAULT”/>
<!– 设置触发延迟加载的方法 –>
<setting name=“lazyLoadTriggerMethods” value=“equals,clone,hashCode,toString”/>
</settings>