当前位置:   article > 正文

数据库批处理的几种方法_批处理数据源

批处理数据源

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/964881
推荐阅读
相关标签
  

闽ICP备14008679号