如何在 JDBC 中启动事务?

2023-12-10

Connection.setTransactionIsolation(int) warns:

注意:如果在事务期间调用此方法,则结果是实现定义的。

这就提出了一个问题:如何在 JDBC 中开始事务?如何结束交易很清楚,但如何开始交易却不清楚。

If a Connection从事务内部开始,我们应该如何调用Connection.setTransactionIsolation(int)在事务之外以避免特定于实现的行为?


回答我自己的问题:

  • JDBC 连接开始于启用自动提交模式,其中每个 SQL 语句都隐式地用事务划分。
  • 希望每个事务执行多个语句的用户必须转向自动提交关闭.
  • 更改自动提交模式会触发当前事务的提交(如果该事务处于活动状态)。
  • Connection.setTransactionIsolation()如果启用了自动提交,则可以随时调用。
  • 如果自动提交被禁用,Connection.setTransactionIsolation()只能在事务之前或之后调用。在事务中间调用它会导致未定义的行为。

See JDBC教程由甲骨文公司。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 JDBC 中启动事务? 的相关文章

随机推荐