executeBatch的使用心得

1.建立链接,(打电话拨号 )

Connection connection =getConnection();

2.不自动 Commit (瓜子不是一个一个吃,全部剥开放桌子上,然后一口舔了)

connection.setAutoCommit(false);

注意:批量处理数据前必须关闭自动提交,保证未提交前的操作处于一个事物,一旦出现异常可以回滚成功。

3.预编译SQL语句,只编译一回哦,效率高啊.(发明一个剥瓜子的方法,以后不要总想怎么剥瓜子好.就这样剥.)

PreparedStatement statement = connection.prepareStatement("INSERT INTO TABLEX VALUES(?, ?)");

4.来一个剥一个,然后放桌子上

//记录1

statement.setInt(1, 1);

statement.setString(2, "Cujo");

statement.addBatch();

 

//记录2

statement.setInt(1, 2);

statement.setString(2, "Fred");

statement.addBatch();

 

//记录3

statement.setInt(1, 3);

statement.setString(2, "Mark");

statement.addBatch();

 

//批量执行上面3条语句. 一口吞了,很爽

int [] counts = statement.executeBatch();

statement .clearBatch(); //数据量过大时候,必须清空batch。

statement.close(); //数据量过大时候,必须关闭,否则超过最大游标数。

 

//Commit it 咽下去,到肚子(DB)里面

connection.commit(); //执行完executeBatch()必须提交。

 

使用注意事项:(这些都是个人实践心得)

1、必须将自动提交关闭,因为数据处理异常回滚时候可保证提交前的操作处于同一事物,保证回滚成功。

2、executeBatch()使用完后必须clearBatch(),清空batch容器,避免数据量过大导致的虚拟机内存溢出。

3、executeBatch()之后clearBatch(),接着必须close()资源。否则占用资源,报错JAVA heap space内存溢出。

4、在循环里边处理数据时候一定不能有频繁创建对象的操作,如果有可以定义全局私有变量,每次初始化时候创建一次,以后直接使用即可。频繁创建对象浪费内存,报错JAVA heap space内存溢出。

5、处理各阶段的错误,推荐使用异常的传递机制,通过方法头抛出异常,最后在总方法catch捕获异常,输出错误信息。

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值