ibatis批处理提高性能

ibatis循环处理与批处理--以插入操作为例

1.循环处理

循环操作的ibatis配置


<!-- 插入一条记录 -->
<insert id="insertUser" parameterClass="User">
<![CDATA[
insert into user(
id,
userName,
passWord
)values(
#id#,
#userName#,
#passWord#
)
]]>
</insert>


循环操作的Junit测试


/**
* 循环插入一条用户记录
* @throws Exception
*/
public void insertTest() throws Exception{
Long oldTime = System.currentTimeMillis();
//System.out.println(oldTime);
for(int i= 0; i < 10000 ; i++){
User user = new User();
user.setId(String.valueOf(i));
user.setUserName("用户"+ i);
user.setPassWord("user"+ i);
new UserDaoImpl().insert(user);
System.out.println(i);
}
System.out.println("循环插入多条记录所花费的时间:"+ (System.currentTimeMillis()-oldTime)/1000.00 +"s");
}


2.批处理

批处理的ibatis配置


<!-- 插入多条记录 -->
<insert id="insertUserList" parameterClass="java.util.List">
<![CDATA[
insert into user(
id,
userName,
passWord
) values
]]>
<iterate conjunction=",">
<![CDATA[
(
#list[].id#,
#list[].userName#,
#list[].passWord#
)
]]>
</iterate>
</insert>


批处理Junit测试


/**
* 插入多条记录 --快
* @throws Exception
*/
public void insertListTest() throws Exception{
Long oldTime = System.currentTimeMillis();
//System.out.println(oldTime);
List<User> users = new ArrayList<User>();
for(int i=0; i< 10000; i++){
User user = new User();
user.setId(String.valueOf(i));
user.setUserName("用户"+ i);
user.setPassWord("user"+ i);
users.add(user);
System.out.println(i);
}
new UserDaoImpl().insertList(users);
System.out.println("一次插入多条记录所花费的时间:"+ (System.currentTimeMillis()-oldTime)/1000.00 +"s");
}


从上面的例子能够测试出批处理的性能高于循环处理的性能。在实际的项目中,对于一次需要插入多条数据,应该使用批处理。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值