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