赞
踩
首先,要关闭数据库连接的自动提交。否则就不叫批处理了,哈哈。
connect.setAutoCommit(false);
然后,判断该数据库是否支持批更新。
DatabaseMetaData dbmData = connect.getMetaData();
//...
if (dbmData.supportsBatchUpdates())
{
//使用Statement创建批处理
statement.addBatch("你的SQL语句");
//根据需要添加多条批处理
statement.addBatch("你的SQL语句");
//获得批处理的结果
int[] uCounts = statement.executeBatch();
//等全部添加好了之后,可以一次性递交了。
connect.commit();
//使用PreparedStatement进行批处理
PreparedStatement psStatement = connect.prepareStatement("你的SQL语句(?)");
psStatement.setString(1,"Jennie");
psStatement.addBatch();
//根据需要添加多条批处理语句
psStatement.setString(1,"Tom");
psStatement.addBatch();
//获得批处理的结果
int[] uCounts = psStatement.executeBatch();
//和上面一样可以一次性执行
connect.commit();
//使用CallableStatement进行批处理
CallableStatement cStatement = connect.prepareCall("{call 你的存储过程(?))");
cStatement.setString(1,"Jennie");
cStatement addBatch();
//根据需要添加多条批处理语句
cStatement.setString(1,"Tom");
cStatement.addBatch();
//获得批处理的结果
int[] uCounts = cStatement.executeBatch();
//和上面一样可以一次性执行
connect.commit();
}
最后可以通过捕获 BatchUpdateException 异常的getUpdateCounts()方法,返回的int[]值,来获得每一条批处理的处理数量。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。