第十节 JDBC事务

news/2024/5/19 0:49:24 标签: oracle, 数据库, java, 后端, mysql, 事务, JDBC

如果JDBC连接处于自动提交模式,默认情况下,则每个SQL语句在完成后都会提交到数据库

对于简单的应用程序可能没有问题,但是有三个原因需要考虑是否关闭自动提交并管理自己的事务 -

  • 提高性能
  • 保持业务流程的完整性
  • 使用分布式事务

事务能够控制何时更改提交并应用于数据库。 它将单个SQL语句或一组SQL语句视为一个逻辑单元,如果任何语句失败,整个事务将失败。

要启用手动事务支持,而不是使用JDBC驱动程序默认使用的自动提交模式,请调用Connection对象的setAutoCommit()方法。 如果将布尔的false传递给setAutoCommit(),则关闭自动提交。 也可以传递一个布尔值true来重新打开它。

例如,如果有一个名为connConnection对象,请将以下代码关闭自动提交 -

conn.setAutoCommit(false);

Java

提交和回滚

完成更改后,若要提交更改,那么可在连接对象上调用commit()方法,如下所示:

conn.commit( );

Java

否则,要使用连接名为conn数据库回滚更新,请使用以下代码 -

conn.rollback( );

Java

以下示例说明了如何使用提交和回滚对象 -

try{
   //Assume a valid connection object conn
   conn.setAutoCommit(false);
   Statement stmt = conn.createStatement();

   String SQL = "INSERT INTO Employees  " +
                "VALUES (106, 20, 'Rita', 'Tez')";
   stmt.executeUpdate(SQL);  
   //Submit a malformed SQL statement that breaks
   String SQL = "INSERTED IN Employees  " +
                "VALUES (107, 22, 'Sita', 'Singh')";
   stmt.executeUpdate(SQL);
   // If there is no error.
   conn.commit();
}catch(SQLException se){
   // If there is any error.
   conn.rollback();
}

Java

在这种情况下,上述INSERT语句不会成功执行,因为所有操作都被回滚了。

为了更好的理解,建议学习研究“事务提交示例代码”。

使用保存点

新的JDBC 3.0新添加了Savepoint接口提供了额外的事务控制能力。大多数现代DBMS支持其环境中的保存点,如Oracle的PL/SQL。

设置保存点(Savepoint)时,可以在事务中定义逻辑回滚点。 如果通过保存点(Savepoint)发生错误时,则可以使用回滚方法来撤消所有更改或仅保存保存点之后所做的更改。

Connection对象有两种新的方法可用来管理保存点 -

  • setSavepoint(String savepointName): - 定义新的保存点,它还返回一个Savepoint对象。
  • releaseSavepoint(Savepoint savepointName): - 删除保存点。要注意,它需要一个Savepoint对象作为参数。 该对象通常是由setSavepoint()方法生成的保存点。

有一个rollback (String savepointName)方法,它将使用事务回滚到指定的保存点。

以下示例说明了使用Savepoint对象 -

try{
   //Assume a valid connection object conn
   conn.setAutoCommit(false);
   Statement stmt = conn.createStatement();

   //set a Savepoint
   Savepoint savepoint1 = conn.setSavepoint("Savepoint1");
   String SQL = "INSERT INTO Employees " +
                "VALUES (106, 24, 'Curry', 'Stephen')";
   stmt.executeUpdate(SQL);  
   //Submit a malformed SQL statement that breaks
   String SQL = "INSERTED IN Employees " +
                "VALUES (107, 32, 'Kobe', 'Bryant')";
   stmt.executeUpdate(SQL);
   // If there is no error, commit the changes.
   conn.commit();

}catch(SQLException se){
   // If there is any error.
   conn.rollback(savepoint1);
}

Java

在这种情况下,上述INSERT语句都不会成功,因为所有操作都被回滚了。


http://www.niftyadmin.cn/n/5424024.html

相关文章

[实测]:claude-3-opus模型-基础能力对比测试

对比模型为: GPT-4GPT3.5,claude-3-sonnet claude3的版本 性能基准对比结果 问题1: 鲁迅为什么暴打周树人 From GPT-4 这是一个误解。鲁迅和周树人其实是同一个人,是中国现代文学的奠基人。他原名周树人,后来以鲁迅为笔名。所以,…

Linux纯命令行查看文本文件

处理超大文本文件时,你可能希望避免一次性加载整个文件,这可能会耗尽内存资源。以下是一些在命令行中查看大文本文件的方法,它们适用于Linux和Unix系统,包括Mac OS X,而在Windows中,你可以使用类似的工具或…

【数据结构学习笔记】冒泡排序

【数据结构学习笔记】冒泡排序 参考电子书:排序算法精讲 算法原理 对未排序的元素进行多次遍历,每次遍历都将相邻的两个元素进行比较,如果它们的顺序错误就交换它们的位置。在每一轮遍历后,最大的元素会被冒泡到序列的末端。这…

meta元数据元素

文章目录 元数据Metadatameta标签的四种使用方式meta的属性meta使用示例 HTML <meta> 元素表示那些不能由其他 HTML标签&#xff08; <style>、 <script>等&#xff09;表示的元数据信息。 元数据Metadata Metadata元数据&#xff0c;简单地来说就是描述…

蓝桥杯刷题--python-19--归并排序,离散化,hash,逆序数

505. 火柴排队 - AcWing题库 nint(input()) alist(map(int,input().split())) blist(map(int,input().split())) mod99999997 # map c[0 for i in range (n1)] # 归并排序模板 def _MergeSort(arr,l,r,tmp): if l>r: return 0 # 分治思想 midlr>>1 # …

leetcode264--丑数II

1. 题意 求第 k k k大的 2 i 3 j 5 k 2^{i}3^{j}5^{k} 2i3j5k 丑数II 2. 题解 2.1 最小堆哈希表 从最小的数开始&#xff0c;生成 2 i 3 i 5 i 2i\ 3i\ 5i 2i 3i 5i;判断这些数是否生成过&#xff0c;没生成过再将其插入堆中。 class Solution { public:int nthUglyNumbe…

软件测试知识面试题:测试计划关键、BUG流程、BUG描述、测试的整体覆盖率

文章目录 做好测试计划工作的关键是什么&#xff1f;公司的BUG流程是什么&#xff1f;如何提交一个好的bug&#xff1f;BUG描述包含哪些内容&#xff1f;讲述自己在项目中发现最有意义的一个 BUG&#xff0c;是什么导致出现这个问题&#xff1f;&#xff08;例子&#xff09;对…

解除网页文本禁止复制限制方法

前言 在我们日常浏览网页和查找资料时&#xff0c;经常需要复制一些文字内容进行引用、收藏或摘抄。 然而&#xff0c;我们也会遇到一些网站上的内容无法复制&#xff0c;这通常是因为网站本身具有禁止复制的限制。 找到的资料如果需要一个个字手打&#xff0c;效率实在太低…