mybatis批量插入時,有字段可能為null會報錯問題
解決方案
在指定了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設(shè)為null,是不是批量操作都可以這么設(shè)
產(chǎn)生的原因
設(shè)置的JDBC類型為空時,某些驅(qū)動程序要指定值,默認是OTHER并不是BULL,mybatis此時是無法處理null值的
記一下mybatis常見配置設(shè)置
<!– 配置設(shè)置 –>
<settings>
<!– 配置全局性 cache 的 ( 開 / 關(guān)) default:true –>
<setting name=“cacheEnabled” value=“true”/>
<!– 是否使用 懶加載 關(guān)聯(lián)對象 同 hibernate中的延遲加載 一樣 default:true –>
<setting name=“l(fā)azyLoadingEnabled” value=“true”/>
<!– [當(dāng)對象使用延遲加載時 屬性的加載取決于能被引用到的那些延遲屬性,否則,按需加載(需要的是時候才去加載)] –>
<setting name=“aggressiveLazyLoading” value=“true”/>
<!– 是否允許單條sql 返回多個數(shù)據(jù)集 (取決于驅(qū)動的兼容性) default:true –>
<setting name=“multipleResultSetsEnabled” value=“true”/>
<!– 是否可以使用列的別名 (取決于驅(qū)動的兼容性) default:true–>
<setting name=“useColumnLabel” value=“true”/>
<!–允許JDBC 生成主鍵。需要驅(qū)動器支持。如果設(shè)為了true,這個設(shè)置將強制使用被生成的主鍵,有一些驅(qū)動器不兼容不過仍然可以執(zhí)行。 default:false–>
<setting name=“useGeneratedKeys” value=“false”/>
<!–指定 MyBatis 如何自動映射 數(shù)據(jù)基表的列 NONE:不隱射 PARTIAL:部分 FULL:全部–>
<setting name=“autoMappingBehavior” value=“PARTIAL”/>
<!– 這是默認的執(zhí)行類型
SIMPLE :簡單
REUSE:執(zhí)行器可能重復(fù)使用prepared statements 語句
BATCH:執(zhí)行器可以重復(fù)執(zhí)行語句和批量更新
–>
<setting name=“defaultExecutorType” value=“SIMPLE”/>
<!– 設(shè)置驅(qū)動等待數(shù)據(jù)響應(yīng)的超時數(shù) 默認沒有設(shè)置–>
<setting name=“defaultStatementTimeout” value=“25000″/>
<!– [是否啟用 行內(nèi)嵌套語句 defaut:false] –>
<setting name=“safeRowBoundsEnabled” value=“false”/>
<!– [是否 啟用 數(shù)據(jù)中 A_column 自動映射 到 java類中駝峰命名的屬性 default:fasle] –>
<setting name=“mapUnderscoreToCamelCase” value=“false”/>
<!– 設(shè)置本地緩存范圍 session:就會有數(shù)據(jù)的共享 statement:語句范圍 (這樣就不會有數(shù)據(jù)的共享 ) defalut:session –>
<setting name=“l(fā)ocalCacheScope” value=“SESSION”/>
<!– 設(shè)置但JDBC類型為空時,某些驅(qū)動程序要指定值,default:OTHER –>
<setting name=“jdbcTypeForNull” value=“DEFAULT”/>
<!– 設(shè)置觸發(fā)延遲加載的方法 –>
<setting name=“l(fā)azyLoadTriggerMethods” value=“equals,clone,hashCode,toString”/>
</settings>
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot+Vue實現(xiàn)EasyPOI導(dǎo)入導(dǎo)出的方法詳解
項目開發(fā)過程中,很大的需求都有 導(dǎo)入導(dǎo)出功能。本文將利用SpringBoot+Vue實現(xiàn)EasyPOI導(dǎo)入導(dǎo)出功能,感興趣的可以了解一下2022-08-08
Java Object類詳解_動力節(jié)點Java學(xué)院整理
Java作為一個龐大的知識體系,涉及到的知識點繁多,本文將從Java中最基本的類java.lang.Object開始談起,對java object類相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧2017-04-04
SpringMVC中的HandlerMapping和HandlerAdapter詳解
這篇文章主要介紹了SpringMVC中的HandlerMapping和HandlerAdapter詳解,在Spring MVC中,HandlerMapping(處理器映射器)用于確定請求處理器對象,請求處理器可以是任何對象,只要它們使用了@Controller注解或注解@RequestMapping,需要的朋友可以參考下2023-08-08

