欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ibatis結(jié)合oracle批量插入三種方法的測(cè)評(píng)

 更新時(shí)間:2018年12月11日 14:40:50   作者:執(zhí)筆記憶的空白  
今天小編就為大家分享一篇關(guān)于ibatis結(jié)合oracle批量插入三種方法的測(cè)評(píng),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

第一種

< 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)鏈接

相關(guān)文章

  • springboot-jta-atomikos多數(shù)據(jù)源事務(wù)管理實(shí)現(xiàn)

    springboot-jta-atomikos多數(shù)據(jù)源事務(wù)管理實(shí)現(xiàn)

    本文主要介紹了springboot-jta-atomikos多數(shù)據(jù)源事務(wù)管理實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Java爬蟲(Jsoup與WebDriver)的使用

    Java爬蟲(Jsoup與WebDriver)的使用

    這篇文章主要介紹了Java爬蟲(Jsoup與WebDriver)的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • spring中實(shí)現(xiàn)容器加載完成后再執(zhí)行自己的方法

    spring中實(shí)現(xiàn)容器加載完成后再執(zhí)行自己的方法

    這篇文章主要介紹了spring中實(shí)現(xiàn)容器加載完成后再執(zhí)行自己的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • java中生成任意之間數(shù)的隨機(jī)數(shù)詳解

    java中生成任意之間數(shù)的隨機(jī)數(shù)詳解

    這篇文章主要介紹了java中生成任意之間數(shù)的隨機(jī)數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Java8之Stream流代替For循環(huán)操作

    Java8之Stream流代替For循環(huán)操作

    這篇文章主要介紹了Java8之Stream流代替For循環(huán)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Reactive反應(yīng)式編程及使用介紹

    Reactive反應(yīng)式編程及使用介紹

    這篇文章主要介紹了為什使用Reactive反應(yīng)式編程的原因分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進(jìn)步,早日升職加薪
    2022-02-02
  • spring配置定時(shí)任務(wù)的幾種方式總結(jié)

    spring配置定時(shí)任務(wù)的幾種方式總結(jié)

    這篇文章主要介紹了spring配置定時(shí)任務(wù)的幾種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Java分別利用深度優(yōu)先和廣度優(yōu)先求解迷宮路徑

    Java分別利用深度優(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ò)的問題

    這篇文章給大家介紹了如何解決springboot3.2集成mybatis-plus3.5.4.1報(bào)錯(cuò)的問題,文中通過圖文介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-12-12
  • SpringSecurity自定義登錄界面

    SpringSecurity自定義登錄界面

    這篇文章主要為大家詳細(xì)介紹了SpringSecurity自定義登錄界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-09-09

最新評(píng)論