数据库批处理的几种方法

来源:互联网 发布:2016部门决算软件 编辑:程序博客网 时间:2024/06/06 03:06

首先,要关闭数据库连接的自动提交。否则就不叫批处理了,哈哈。
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[]值,来获得每一条批处理的处理数量。


 
原创粉丝点击