ibatis結(jié)合oracle批量插入三種方法的測(cè)評(píng)
第一種
< insert id =" insert_table " parameterClass ="java.util.List" > <![CDATA[ insert into sj_test( col1 , col2 , col3 ) values ]]> < iterate conjunction ="," > <![CDATA[ (#test[]. col1 #, # test []. col2 #, # test []. col3 #) ]]> </ iterate > </ insert >
這種方式是網(wǎng)上最常見的,但是也是問題最大的,今天把我徹底糾結(jié)了,弄了幾個(gè)小時(shí),最后發(fā)現(xiàn),Oracle
不支持 一個(gè)insert
多個(gè)values
的方式,不知道網(wǎng)友們被坑到了沒,好像MySQL
支持這種方式,所報(bào)的錯(cuò)誤:ORA-00933:SQL命令未正確結(jié)束
第二種
<insert id="insert_table " parameterClass="java.util.List"> insert all <iterate conjunction=""> into sj_test( col1 , col2 , col3 ) values (#test[]. col1 #, # test []. col2 #, # test []. col3 #) </iterate> <!--必須要加上 --> select * from dual </insert>
這種方式,Oracle
支持,其他的數(shù)據(jù)庫就不知道支不支持,但是這種方式有個(gè)局限性,就是你插入的表的列數(shù)* 你插入的行數(shù) <1000 才有效
如:
我今天需要插入的表有13列字段,總共需要插入246行,在執(zhí)行的時(shí)候
他就報(bào):ORA-24335 cannot support more than 1000 columns
第三種方式
<insert id="insert_table" parameterClass="java.util.List"> insert into sj_test( col1 , col2 , col3 ) values select col1 , col2 , col3 from ( <iterate conjunction=" union all "> select #test[].col1# as col1 , #test []. col2# as col2, # test[].col3# as col3 from dual </iterate> ) </insert>
這種方式 是先將List
里面的值,循環(huán)拼接成一個(gè)查詢虛擬表,然后再通過查詢虛擬表,獲取每一行的數(shù)據(jù) 插入到你需要插入的表里面去. 這樣的話有個(gè)需要注意的地方,就是你拼接的SQL
語句的長(zhǎng)度有沒有超過Oracle
的最大長(zhǎng)度,不過Oracle
的最大長(zhǎng)度是64KB,你的SQL
語句應(yīng)該不會(huì)寫這么長(zhǎng)吧?
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- struts2+spring+ibatis框架整合實(shí)現(xiàn)增刪改查
- 在Spring使用iBatis及配置講解
- java~springboot~ibatis數(shù)組in查詢的實(shí)現(xiàn)方法
- ibatis遷移到mybatis3的注意事項(xiàng)
- 通過ibatis解決sql注入問題
- ibatis學(xué)習(xí)之搭建Java項(xiàng)目
- Mybatis報(bào)錯(cuò): org.apache.ibatis.exceptions.PersistenceException解決辦法
- Mybatis與Ibatis的區(qū)別
- Ibatis配置xml文件CDATA使用方法詳解
相關(guān)文章
springboot-jta-atomikos多數(shù)據(jù)源事務(wù)管理實(shí)現(xiàn)
本文主要介紹了springboot-jta-atomikos多數(shù)據(jù)源事務(wù)管理實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03spring中實(shí)現(xiàn)容器加載完成后再執(zhí)行自己的方法
這篇文章主要介紹了spring中實(shí)現(xiàn)容器加載完成后再執(zhí)行自己的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02java中生成任意之間數(shù)的隨機(jī)數(shù)詳解
這篇文章主要介紹了java中生成任意之間數(shù)的隨機(jī)數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09spring配置定時(shí)任務(wù)的幾種方式總結(jié)
這篇文章主要介紹了spring配置定時(shí)任務(wù)的幾種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Java分別利用深度優(yōu)先和廣度優(yōu)先求解迷宮路徑
這篇文章主要為大家詳細(xì)介紹了Java如何利用深度優(yōu)先的非遞歸遍歷方法和廣度優(yōu)先的遍歷方法實(shí)現(xiàn)求解迷宮路徑,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-08-08解決springboot3.2集成mybatis-plus3.5.4.1報(bào)錯(cuò)的問題
這篇文章給大家介紹了如何解決springboot3.2集成mybatis-plus3.5.4.1報(bào)錯(cuò)的問題,文中通過圖文介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2023-12-12