java 事务级别_java事务隔离级别

article/2025/10/3 3:22:35

事务隔离级别是由数据库系统实现的。

Java事务

1) 说到事务,不得不提的就是ACID特性,再次回顾:

Ø 原子性(atomicity):组成事务处理的语句形成了一个逻辑单元,不能只执行其中的一部分。

Ø 一致性(consistency):在事务处理执行前后,数据库是一致的(数据库数据完整性约束)。

Ø 隔离性(isolcation):一个事务处理对另一个事务处理的影响。

Ø 持续性(durability):事务处理的效果能够被永久保存下来 。

2) 然后就是事务在Java中的最基本操作:

Ø connection.setAutoCommit(false);//打开事务。

Ø connection.commit();//提交事务。

Ø connection.rollback();//回滚事务。

这里需要提的就是,当只想撤销事务中的部分操作时可使用SavePoint:

Ø SavePoint sp = connection.setSavepoint();

Ø connection.rollerbak(sp);connection.commit();

3) 下面用一个实例代码来展示一下:

1. package cn.itcast.jdbc;

3. import java.sql.Connection;

4. import java.sql.ResultSet;

5. import java.sql.SQLException;

6. import java.sql.Savepoint;

7. import java.sql.Statement;

8. /**

9. * 事务测试

10. */

11. public class SavePointTest {

13. public static void main(String[] args) throws SQLException {

14. testTransaction();

15. }

17. static void testTransaction() throws SQLException {

18. Connection conn = null;

19. Statement st = null;

20. ResultSet rs = null;

21. Savepoint sp = null;

22. try {

23. //获取Connection(JdbcUtils为自定义的包装类,这里不做解释)

24. conn = JdbcUtils.getConnection();

25. //开启事务

26. conn.setAutoCommit(false);

27. st = conn.createStatement();

28. //id为1的人的Money减10

29. String sql = "update user set money=money-10 where id=1";

30. st.executeUpdate(sql);

31. //********************回滚界限***************************

32. //设置回滚点(savepoint)

33. sp = conn.setSavepoint();

34. //********************回滚界限***************************

35. //id为2的人的Money减10

36. sql = "update user set money=money-10 where id=3";

37. st.executeUpdate(sql);

38. sql = "select money from user where id=2";

39. rs = st.executeQuery(sql);

40. float money = 0.0f;

41. if (rs.next()) {

42. money = rs.getFloat("money");

43. }

44. if (money > 300){

45. throw new RuntimeException("已经超过最大值!");

46. }

47. //id为2的人的Money加10

48. sql = "update user set money=money+10 where id=2";

49. st.executeUpdate(sql);

50. //提交事务

51. conn.commit();

52. } catch (RuntimeException e) {

53. if (conn != null && sp != null) {

54. //回滚事务,注意里面的参数sp即为我们上面设置的savePoint,如果回滚的话只能回滚到savePoint以下的部分

55. //上面的部分不会得到回滚

56. conn.rollback(sp);

57. conn.commit();

58. }

59. throw e;

60. } catch (SQLException e) {

61. if (conn != null)

62. conn.rollback();

63. throw e;

64. } finally {

65. //释放资源(JdbcUtils为自定义类)

66. JdbcUtils.free(rs, st, conn);

67. }

68. }

69. }

上面所有的操作(CRUD)都是在同一个数据源上的操作,无法处理跨多数据源(分布式)操作。跨多个数据源的事务就要使用JTA容器实现事务。根本思想就是“分成两阶段提交”,具体内容这里不做介绍。

1.javax.transaction.UserTransaction tx = (UserTransaction)ctx.lookup(“jndiName");

2. tx.begin();

3. //connection1 connection2 (可能来自不同的数据库)…

4. tx.commit();//tx.rollback();

隔离级别

为了应对多线程并发读取数据时出现的问题,事务有了“隔离级别”特性,多线程并发读取数据一般会引发如下三个问题:

Ø 脏读(dirtyreads)

Ø 不可重复读(non-repeatablereads)

Ø 幻读(phantomread)

下面进行简要介绍:

Ø 脏读:一个事务读取了另一个未提交的并行事务写的数据。

Ø 不可重复读:一个事务重新读取前面读取过的数据, 发现该数据已经被另一个已提交的事务修改过。

Ø 幻读:一个事务重新执行一个查询,返回一套符合查询条件的行, 发现这些行因为其他最近提交的事务而发生了改变。

2) 为了处理上面的读数据问题,java事务提供了4种隔离级别,如下:

Ø 读未提交(Read uncommitted)

Ø 读已提交(Readcommitted)

Ø 可重复读(Repeatableread)

Ø 可串行化(Serializable)

3) 4种隔离级别与上面3个问题的对应关系如下:

372647f68236

image

注意上面的“可能”二字。

4) 隔离级别的设定:

connection.setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED);

在代码中的应用:

372647f68236

image

转载文章https://blog.csdn.net/dragon901/article/details/79849492


http://chatgpt.dhexx.cn/article/cqqcxW6B.shtml

相关文章

Java中使用事务(注解实现)

Java中使用事务(注解实现) 事务的介绍 描述: 对于一个功能实现或者业务流程,要么全做,要么全不做! 特性: ACID A - 原子性:执行的最小单位,要么全做,要么全…

JAVA的事务

要先知道什么是java中的事务? 事务: 一般是指要做的或所做的事情.专业术语是这样说的: 就是代码逻辑上的一组操作,这些操作要么全部成功,要么全部失败!举一个现实生活当中的例子: 1张三账上有2000元,李四账号也有2000元。张三要向李四转账1000元,正常来…

Java中的事务

一、事务概述 1. 什么是事务 事务是指对数据库的一系列的操作序列,数据库应用系统通过事务集来完成对数据的存取操作。 2. 事务的特性(ACID原则) 原子性(Atomicity):一个事务的操作不可分割&#xff0c…

java事务总述

文章目录 一、java事务概述1.1、java事务简述1.2、Java事务的类型1.3、java事务的特性1.4、java事务的隔离级别1.5、spring事务的传播特性1.6、spring支持的事务管理类型 二、java事物使用2.1、XML配置2.2、事务使用方式 一、java事务概述 1.1、java事务简述 1、简介 事务(TR…

Java中的事务及使用

什么是事务? 事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如SQL,C或Java&am…

测试用例设计方法---等价类划分法

1 等价类划分法 1.1 定义 是把所有可能输入的数据,即程序的输入域划分策划国内若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。方法是一种重要的、常用的黑盒测试用例设计方法。 1.1划分等价类 1&a…

02测试用例设计方法-等价类划分

等价类划分法 1)定义 是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。该方法是一种重要的,常用的黑盒测试用例设计方法。使用这一方法时,完全不考虑程序的…

等价类划分用例案例设计

一、加法案例 测试要求:计算1到100的两个整数之和(包括1和100) 提示:一般是一个框输入正确的值,一个框输入错误的值,没有两个框都输入错误的值,因为更容易确定到底是哪个框出现错误的值&#x…

常见测试用例设计方法1---等价类划分

目录 一,等价类划分概念: 二,有效等价类和无效等价类: 三,划分等价类的标准 四,设计测试用例 五,以QQ密码设定规则为例使用等价类划分编写测试用例 1,分析需求,确定输…

黑盒测试方法|测试用例的设计方法--等价类划分方法

黑盒测试方法–测试用例的设计方法–等价类划分方法 目录 等价类划分方法边界值分析方法错误推测方法因果图方法判定表驱动分析方法正交实验设计方法功能图分析方法场景设计方法 等价类划分方法 一、方法简介 (1)定义 把所有可能的输入数据,即程序的…

软件测试:等价类划分举例

等价类的设计思路: 根据输入条件,确定等价类,包括有效等价类和无效等价类,建立等价类列表为每个等价类规定一个唯一的编号设计一个测试用例,使其尽可能多地覆盖尚未被覆盖的有效等价类,重复这一步&#xff…

等价类划分法-案例剖析-设计测试用例

目录 等价类划分法概念 有效等价类和无效等价类 等价类设计测试用例步骤 案例1 案例2 案例3 等价类划分法概念 等价类划分法是把所有可能的输入数据,即程序的输入数据集合划分成若干个子集即等价类,然后从每个等价类中选取少量具有代表性的数据作为…

15.3-等价类划分

目录 一、等价类划分的概念 二、使用等价类划分的原因 三、等价类划分的价值 四、相关概念 1、等价类 2、有效等价类 3、无效等价类 五、等价类划分法使用步骤 六、等价类的划分原则 1、原则1 2、原则2 3、原则3 4、原则4 5、原则5 6、原则6 七、测试用例的设计步骤 八、等价类…

软件测试用例设计 (一)等价类划分法

软件测试对于软件的重要性不言而喻,是计算机类学生毕业后的一个重要从业方向之一。 如果要从事软件测试,那么有些必备的技能还是要有的。比如,测试理论、测试工具、测试文档的编制。 今天我们就来看看最最最重要的测试理论:黑盒…

测试用例设计——等价类划分法

一、分析问题 如果我们需要对下面的这个两位数加法器设计测试用例,在测试了1+1,1+2,(-1)1和(-1)+2之后,是否有必要测试1+3&#xff0c…

等价类划分法设计用例(超详细)

等价类划分法 等价类: 1、解决了不能穷举测试的问题、控制成本、控制测试用例数量 2、数据值要明确,对文字敏感 3、依据需求将输入划分为若干个等价类,划分等价类(需求、数据特征) 等价类设计用例的难点:…

测试用例设计方法 之【等价类划分法】

前言: 在没有测试用例之前,团队里的成员进行测试时,完全“以人为本”,根据个人思路、需求理解度、发散性思想来完成测试系统,人无完人,弊端显而易见。衍生出【测试用例】后,测试工作的目标得到…

等价类划分法测试用例设计举例

一、基本概念 等价类是指程序输入域的子集。 等价类划分(Equivalance Partitioning)测试的思想:将程序的输入域划分为若干个区域(等价类),并在每个等价类中选择一个具有代表性的元素生成测试用例。该方法…

等价类划分测试用例设计方法

一.方法简介 1.定义 是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子集中选取少数具有代表性的数据作为测试用例。该方法是一种重要的,常用的黑盒测试用例设计方法。 2.划分等价类 等价类是指某个输入域的子集合。在该子集合…

编写测试用例方法之等价类划分法

今天我们再来介绍另外一个编写测试用例的方法:等价类划分法,这个方法是最常用的写用例的方法。话不多说,开始整干货,首先,全图镇楼。 之前我们是如何测试一个商品的呢?产品就是要有它的测试点。测试点之前也…