【问题标题】:Execute two different queries in one transaction在一个事务中执行两个不同的查询
【发布时间】:2011-06-19 03:20:41
【问题描述】:

我正在尝试在一个Statement 中执行两个插入查询,并将它们放在一个事务中。

我正在查看 addBatch 方法,但如果我理解正确,它可以与单个 PreparedStatement 一起使用,以使用不同的参数多次执行相同的插入,或者用于 Statement 对象添加对批处理的更多查询,但无法添加参数(因此我可能能够在 sql 字符串中添加值。SQL 注入样式)。

我还尝试了一种在一个 sql 语句 (insert into table1 values(?, ?); insert into table2 values(?, ?);) 中编写两个插入的天真方法,但这样PreparedStatement 只能看到前两个参数,并且尝试设置第 3 个和第 4 个参数会引发异常。

【问题讨论】:

  • 出于好奇,您不想在同一事务中使用两个PreparedStatement 的原因是什么?这会让你的生活更轻松!
  • 是的,我想没有什么特别的理由不这样做,除了不去想它。感谢您指出。

标签: java jdbc prepared-statement


【解决方案1】:

您可以禁用自动提交,执行两个单独的语句,然后手动提交事务:

connection.setAutoCommit(false);
try {
    ...
    stmt1.execute();
    ...
    stmt2.execute();
    connection.commit();
} catch (Exception ex) {
    connection.rollback();
}

【讨论】:

  • 将回滚放在 SQLException 捕获块中是安全的还是更好的做法?
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2018-03-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-12-01
  • 2016-02-07
相关资源
最近更新 更多