mybatis報(bào)Query?was?Empty異常的問(wèn)題
mybatis報(bào)Query was Empty異常
mybatis中的<foreach>標(biāo)簽在批處理的時(shí)候經(jīng)常要使用到,而使用<foreach>避免不了的就是要對(duì)list進(jìn)行非空判斷,否則很容易出錯(cuò)。
今天我在批量插入時(shí),我的代碼是這樣的
<if test="list!=null and list.size>0> ? ?insert into tables ? ?values ? ?<foreach item="item" separator="," open="(" close=")"> #{item} </foreach> </if>
本以為在外面加上判斷就可以啦,但是運(yùn)行時(shí)就拋出了這個(gè)異常:Query was Empty這個(gè)異常,那么這個(gè)異常是怎么來(lái)的呢,其實(shí)就是List為空時(shí),經(jīng)過(guò)<if>標(biāo)簽的判斷,從而使的這個(gè)<insert>標(biāo)簽里面沒(méi)有內(nèi)容,所以就導(dǎo)致了這個(gè)異常:Query was Empty。
我總覺(jué)得這個(gè)東西應(yīng)該是Mybatis的缺陷,怎么每次都要對(duì)這個(gè)list進(jìn)行判斷,而且感覺(jué)判斷起來(lái)還很麻煩,希望以后對(duì)foreach標(biāo)簽會(huì)支持更好一些,用起來(lái)更爽一些。
mybatis批量更新出現(xiàn)Query was Empty
自己在檢查其他情況無(wú)誤的情況下,后臺(tái)還是給我報(bào)錯(cuò)“query was empty”,從字面 意思就是“查詢?yōu)榭?rdquo;,這里表達(dá)的不準(zhǔn)確,這里是因?yàn)槟愕膫魅氲膌ist集合是空集合,而不是查詢結(jié)果為空而引發(fā)的異常,所以我們需要對(duì)集合進(jìn)行判斷是否傳入的是有參數(shù)的集合,以免讓mybatis直接拋出一大串不友好的異常,這里記錄一下。
? ? <update id="updateFeeAndCharge" parameterType="java.util.List"> ? ? ? ? <foreach collection="list" item="items" separator =";"> ? ? ? ? ? ? update item set ? ? ? ? ? ? enroll1=#{items.enroll1}, ? ? ? ? ? ? enroll1=#{items.enroll2}, ? ? ? ? ? ? business1=#{items.business1}, ? ? ? ? ? ? business2=#{items.business2} ? ? ? ? ? ? where id=#{items.id} ? ? ? ? </foreach> ? ? </update>
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java使用阿里云接口進(jìn)行身份證實(shí)名認(rèn)證的示例實(shí)現(xiàn)
這篇文章主要介紹了使用阿里云接口進(jìn)行身份證實(shí)名認(rèn)證的示例實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07Java編程實(shí)現(xiàn)對(duì)十六進(jìn)制字符串異或運(yùn)算代碼示例
這篇文章主要介紹了Java編程實(shí)現(xiàn)對(duì)十六進(jìn)制字符串異或運(yùn)算代碼示例,簡(jiǎn)述了異或運(yùn)算以及具體實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12maven模塊化開(kāi)發(fā)部署實(shí)現(xiàn)方案
有些用戶有定制化需求,需要添加新的模塊功能,因此需要平臺(tái)主體功能迭代的同時(shí),非主體功能和定制化功能插件化,本文給大家介紹maven模塊化開(kāi)發(fā)部署實(shí)現(xiàn)方案,感興趣的朋友一起看看吧2024-01-01Java Big Number操作BigInteger及BigDecimal類詳解
這篇文章主要為大家介紹了Java Big Number操作BigInteger及BigDecimal類詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07Java SQL注入案例教程及html基礎(chǔ)入門(mén)
這篇文章主要介紹了前端開(kāi)發(fā)每天必學(xué)之SQL及HTML入門(mén)基礎(chǔ)知識(shí),介紹了學(xué)習(xí)web前端開(kāi)發(fā)需要掌握的基礎(chǔ)技術(shù),感興趣的小伙伴們可以參考一下2021-07-07為什么JDK8中HashMap依然會(huì)死循環(huán)
這篇文章主要介紹了為什么JDK8中HashMap依然會(huì)死循環(huán),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Spring和MyBatis整合自動(dòng)生成代碼里面text類型遇到的坑
Spring和MyBatis整合以后,使用自動(dòng)生成代碼工具生成dao和mapper配置文件。下面通過(guò)本文給大家介紹Spring和MyBatis整合自動(dòng)生成代碼里面text類型遇到的坑,需要的朋友參考下吧2018-01-01使用?EasyCode生成springboot+mybatis基礎(chǔ)程序的實(shí)現(xiàn)示例
本文主要介紹了使用?EasyCode生成springboot+mybatis基礎(chǔ)程序的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01java開(kāi)發(fā)web前端cookie session及token會(huì)話機(jī)制詳解
如果把人體比作一個(gè)web系統(tǒng)的話,cookie、session和token就好像人體的經(jīng)絡(luò)和血管一樣,而web系統(tǒng)中的數(shù)據(jù),就好像人體的血液一樣。血液依靠著血管在人體內(nèi)流動(dòng),就如數(shù)據(jù)根據(jù)cookie和session機(jī)制在web系統(tǒng)中流動(dòng)一樣2021-10-10