mysqlplus 批量插入_ibatis结合oracle批量插入三种方法的测评
第一種
< insert id =" insert_table " parameterClass ="java.util.List" >
insert into sj_test( col1 , col2 , col3 ) values
]]>
< iterate conjunction ="," >
(#test[]. col1 #, # test []. col2 #, # test []. col3 #)
]]>
iterate >
insert >
這種方式是網上最常見的,但是也是問題最大的,今天把我徹底糾結了,弄了幾個小時,最后發現,Oracle不支持 一個insert多個values的方式,不知道網友們被坑到了沒,好像MySQL支持這種方式,所報的錯誤:ORA-00933:SQL命令未正確結束
第二種
insert all
into sj_test( col1 , col2 , col3 ) values
(#test[]. col1 #, # test []. col2 #, # test []. col3 #)
select * from dual
這種方式,Oracle支持,其他的數據庫就不知道支不支持,但是這種方式有個局限性,就是你插入的表的列數* 你插入的行數 <1000 才有效
如:
我今天需要插入的表有13列字段,總共需要插入246行,在執行的時候
他就報:ORA-24335?cannot?support?more?than?1000?columns
第三種方式
insert into sj_test( col1 , col2 , col3 ) values select
col1 , col2 , col3
from (
select
#test[].col1# as col1 , #test []. col2# as col2, # test[].col3# as col3 from dual
)
這種方式 是先將List里面的值,循環拼接成一個查詢虛擬表,然后再通過查詢虛擬表,獲取每一行的數據 插入到你需要插入的表里面去. ? ?這樣的話有個需要注意的地方,就是你拼接的SQL語句的長度有沒有超過Oracle的最大長度,不過Oracle的最大長度是64KB,你的SQL語句應該不會寫這么長吧?
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
總結
以上是生活随笔為你收集整理的mysqlplus 批量插入_ibatis结合oracle批量插入三种方法的测评的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 3d打印 路径规划_3D打印螺旋桨技术的
- 下一篇: iview的select联动_iview