C_sdn_000000 2011-12-11 20:04
浏览 923
已采纳

Ibatis怎么做批量更新?????

<insert id="updateStatusBatch" parameterClass="hashMap">  
update  
Question  
set  
status = #status#  
<dynamic prepend="where questionId in">  
<isNotNull property="actionIds">  
<iterate property="actionIds" open="(" close=")" conjunction=",">  
#actionIds[]#  
</iterate>  
</isNotNull>  
</dynamic>  
</insert> 

上面的解析成sql就是
update Question  set status = "OK"  where questionId in(1,2,3,4,5...)


到网上找了很多ibatis批量更新的例子,基本上都是这样,我心想难道他们做的项目中只遇到这种把in中的id的status全部更新为同一个值吗,如果每个id对应的status不同呢,怎么做,难道把sql全部放到iterate中吗,这样和for循环没什么区别,郁闷中。。。

小弟不才,刚接触ibatis,想请问ibatis是怎样做批量增改的,

PS:只是单独的ibatis项目,不和spring集成

 

  • 写回答

4条回答 默认 最新

  • iteye_15914 2011-12-12 09:08
    关注

    有的时候,我们需要一次性插入很多的数据或者一次性更新、删除很多的数据,这是为了提高效率。假如不用批处理 ,相当于是一条一条的插入。而批处理是一次性的修改数据,这样减少了数据库连接的消耗。
    至于ibaits 执行
    [code="java"]
    sqlMapClient.startBatch();

    .....
    sqlMapClient.executeBatch();

    [/code]
    ,我认为ibatis是对statement的addBatch()方法做了封装。源码没看过 ,但认为原理是这样。
    在我做过的项目里,基本是一次性修改万级以上的数据时 会用批处理,我会把数据分多批,一批一批的处理 这样速度快。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)