iterate conjunction = , > 這種方式是網(wǎ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é)了,弄了幾個小時,最后發(fā)現(xiàn),Oracle
不支持 一個insert
多個values
的方式,不知道網(wǎng)友們被坑到了沒,好像MySQL
支持這種方式,所報的錯誤: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ù)庫就不知道支不支持,但是這種方式有個局限性,就是你插入的表的列數(shù)* 你插入的行數(shù) <1000 才有效
如:
我今天需要插入的表有13列字段,總共需要插入246行,在執(zhí)行的時候
他就報: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)拼接成一個查詢虛擬表,然后再通過查詢虛擬表,獲取每一行的數(shù)據(jù) 插入到你需要插入的表里面去. 這樣的話有個需要注意的地方,就是你拼接的SQL
語句的長度有沒有超過Oracle
的最大長度,不過Oracle
的最大長度是64KB,你的SQL
語句應(yīng)該不會寫這么長吧?
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對億速云的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。