隨筆 - 175  文章 - 202  trackbacks - 0
          <2008年3月>
          2425262728291
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

          第一個Blog,記錄哈哈的生活

          常用鏈接

          留言簿(16)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          Java links

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          batch_size 即同時提交數(shù)據(jù)的數(shù)量,原本與事務(wù)并沒有什么關(guān)系,但如果涉及到同一張表數(shù)據(jù)的同一種操作,可能就會發(fā)生微妙的關(guān)系了。

          場景如下:
          場景一:使用 spring 控制事務(wù),將方法事務(wù)配置為 not_supported,向同一張表中插入兩條數(shù)據(jù),保證第一條數(shù)據(jù)正常插入,而第二條數(shù)據(jù)受約束(如唯一約束)插入失敗。

          預(yù)測結(jié)果:第一條數(shù)據(jù)成功,第二條失敗。
          實際結(jié)果:兩條數(shù)據(jù)均失敗。
          原因:hibernate 將兩條插入放到了同一個 batch 中,提交同時失敗了。

          場景二:同樣使用 spring 控制事務(wù),將方法事務(wù)配置為 not_supported,向第一張表中插入一條合法數(shù)據(jù),成功,向第二張表插入數(shù)據(jù),受約束(如唯一約束)插入失敗。

          預(yù)測結(jié)果:第一條數(shù)據(jù)成功,第二條失敗。
          實際結(jié)果:第一條數(shù)據(jù)成功,第二條失敗。
          原因:hibernate 分別插入數(shù)據(jù)并提交,在無事務(wù)的情況下,第一條成功,第二條失敗。

          那么如何讓場景一得到預(yù)測結(jié)果呢,一個簡單的解決方法,將 hibernate.jdbc.batch_size 設(shè)置為 1,即可。

          所以,即使控制了事務(wù),也未必能夠得到期望的結(jié)果,還需要考慮某些特殊的場景帶來的影響。
          posted on 2008-03-06 14:18 哈哈的日子 閱讀(1837) 評論(2)  編輯  收藏 所屬分類: Java

          FeedBack:
          # re: Hibernate 的 batch_size 與事務(wù)[未登錄] 2008-03-06 22:55 Doublej
          是不是加上:
          <property name="jdbc.batch_size">1</property>
          我特意試了下.好像還是兩條都不成功...  回復(fù)  更多評論
            
          # re: Hibernate 的 batch_size 與事務(wù) 2008-03-07 11:15 哈哈的日子
          試一下 hibernate.jdbc.batch_size,看看事務(wù)配置,我這邊沒問題。  回復(fù)  更多評論
            
          主站蜘蛛池模板: 那坡县| 漳浦县| 县级市| 钟山县| 舞钢市| 惠州市| 封开县| 马公市| 安阳市| 隆昌县| 蚌埠市| 华容县| 夏河县| 永新县| 涟源市| 怀柔区| 连江县| 会同县| 黎平县| 西和县| 乌拉特后旗| 天祝| 连山| 突泉县| 温宿县| 湘潭市| 长垣县| 抚远县| 通海县| 桐柏县| 陈巴尔虎旗| 顺平县| 城步| 广丰县| 普兰县| 苍南县| 阳春市| 广宗县| 招远市| 长垣县| 衡东县|