`
dingjun1
  • 浏览: 214335 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

事务级别及相关内容

阅读更多
事务的四个属性:原子性(atomicity)、一致性(consistency)、隔离性(isolation)和持久性(durability)。

1.原子性(Atomic)
    最重要的原则,也是最容易理解的原则。被事务管理的所有方法,要么一起被提交,要么一起回滚。

2.一致性(Consistency)
    事务在系统完整性中实施一致性,如果事务成功地完成,那么系统中所有变化将正确地应用,系统处于新有效状态。如果在事务中出现错误,那么系统中的所有变化将自动地回滚,系统返回到原始状态。

3.隔离性(Isolation)
    在隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。如果有两个事务,运行在相同的时间内,执行相同的功能,事务的隔离性将确保每一事务在系统中认为只有该事务在使用系统。这种属性有时称为串行化,为了防止事务操作间的混淆,必须串行化或序列化请求,使得在同一时间仅有一个请求用于同一数据。重要的是,在隔离状态执行事务,系统的状态有可能是不一致的,在结束事务前,应确保系统处于一致状态。但是在每个单独的事务中,系统的状态可能会发生变化。如果事务不是在隔离状态运行,它就可能从系统中访问数据,而系统可能处于不一致状态。通过提供事务隔离,可以阻止这类事件的发生。

4.持久性(Durability)
    持久性意味着一旦事务执行成功,在系统中产生的所有变化将是永久的。应该存在一些检查点防止在系统失败时丢失信息。甚至硬件本身失败,系统的状态仍能通过在日志中记录事务完成的任务进行重建。

数据库锁概念:
    在数据库中有两种基本的锁类型:排它锁(Exclusive Locks,即X锁)和共享锁(Share Locks,即S锁)。当数据对象被加上排它锁时,其他的事务不能对它读取和修改。加了共享锁的数据对象可以被其他事务读取,但不能修改。数据库利用这两种基本的锁类型来对数据库的事务进行并发控制。
    从程序员的角度看,锁分为以下两种类型:
    1.乐观锁(Optimistic Lock)
    乐观锁假定在处理数据时,不需要在应用程序的代码中做任何事情就可以直接在记录上加锁、即完全依靠数据库来管理锁的工作。一般情况下,当执行事务处理时SQL Server会自动对事务处理范围内更新到的表做锁定。
    2.悲观锁(Pessimistic Lock)
    悲观锁对数据库系统的自动管理不感冒,需要程序员直接管理数据或对象上的加锁处理,并负责获取、共享和放弃正在使用的数据上的任何锁。

事务隔离级别
    一个事务必须与其它事务进行隔离的程度。较低的隔离级别可以增加并发,但代价是降低数据的正确性。相反,较高的隔离级别可以确保数据的正确性,但可能对并发产生负面影响。

数据库并发操作存在的异常情况:
1. 更新丢失(Lost update):两个事务都同时更新一行数据但是第二个事务却中途失败退出导致对数据两个修改都失效了这是系统没有执行任何锁操作因此并发事务并没有被隔离开来

2. 脏读取(Dirty Reads):一个事务开始读取了某行数据但是另外一个事务已经更新了此数据但没有能够及时提交。这是相当危险很可能所有操作都被回滚

3. 不可重复读取(Non-repeatable Reads):一个事务对同一行数据重复读取两次但是却得到了不同结果。例如在两次读取中途有另外一个事务对该行数据进行了修改并提交

4. 两次更新问题(Second lost updates problem):无法重复读取特例,有两个并发事务同时读取同一行数据然后其中一个对它进行修改提交而另一个也进行了修改提交这就会造成第一次写操作失效

5. 幻读(Phantom Reads):也称为幻像(幻影)。事务在操作过程中进行两次查询,第二次查询结果包含了第一次查询中未出现的数据(这里并不要求两次查询SQL语句相同)这是因为在两次查询过程中有另外一个事务插入数据造成的

为了避免上面出现几种情况在标准SQL规范中定义了4个事务隔离级别,不同隔离级别对事务处理不同 。

1.未授权读取(Read Uncommitted):也称未提交读。允许脏读取但不允许更新丢失,如果一个事务已经开始写数据则另外一个数据则不允许同时进行写操作但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。事务隔离的最低级别,仅可保证不读取物理损坏的数据。与READ COMMITTED 隔离级相反,它允许读取已经被其它用户修改但尚未提交确定的数据。

2. 授权读取(Read Committed):也称提交读。允许不可重复读取但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现,读取数据的事务允许其他事务继续访问该行数据,但是未提交写事务将会禁止其他事务访问该行。SQL Server 默认的级别。在此隔离级下,SELECT 命令不会返回尚未提交(Committed) 的数据,也不能返回脏数据。

3. 可重复读取(Repeatable Read):禁止不可重复读取和脏读取。但是有时可能出现幻影数据,这可以通过“共享读锁”和“排他写锁”实现,读取数据事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。在此隔离级下,用SELECT 命令读取的数据在整个命令执行过程中不会被更改。此选项会影响系统的效能,非必要情况最好不用此隔离级。

4. 串行(Serializable):也称可串行读。提供严格的事务隔离,它要求事务序列化执行,事务只能一个接着一个地执行,但不能并发执行。如果仅仅通过 “行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作事务访问到。事务隔离的最高级别,事务之间完全隔离。如果事务在可串行读隔离级别上运行,则可以保证任何并发重叠事务均是串行的。


隔离级别 更新丢失 脏读取 重复读取 幻读
未授权读取 N Y Y Y
授权读取 N N Y Y
可重复读取 N N N Y
串行 N N N N


Oracle 支持的 2 种事务隔离级别 Read committed 和 Serializable

根據官方資料,它們的區別如下:

动作                      Read Committed        Serializable
Dirty write           Not possible          Not possible
Dirty read            Not possible          Not possible
Nonrepeatable read    Possible              Not possible
Phantoms              Possible              Not possible

Read committed 是默认的隔离级别。
对于Read committed ,事务中的查询只能看到在此查询之前( 而非事务开始之前 )提交的数据。 由于 oracle 不会因为查询数据而阻止另外一个事务修改数据,因此数据可以在一个事务中的 2 次查询中,查到不同的结果。因此 可能出现 nonrepeatable read and phantoms 的情况

对于serializable transactions ,当2次执行同一条查询语句的时候(就是两次执行查询,就是说执行完第一个 .executeQuery ,然后执行第二个 .executeQuery ),如果在第一个 .executeQuery 开始执行而另外一个事务已经开始修改数据,并且已经提交,那么两次读取的数据是另外一个事务修改前的数据。如果在第一个 .executeQuery 之前,另外一个事务修改了数据,那么两次读取的数据是另外一个事务修改后的数据。

这恰恰反映了, repeatable read ,两次结果一致

这与 Read committed 完全不同, 要是 Read committed ,第一个 .executeQuery 未执行完第二事务,而在第二个 .executeQuery 前第二个事务执行完毕,那么第一个 .executeQuery 得到的是初始数据,而第二个 .executeQuery 得到的是修改后的数据

恰恰说明了 nonrepeatable read ,两次结果不一致的情况
分享到:
评论

相关推荐

    系统架构师必备:深入剖析本地事务隔离级别及并发控制

    内容概要:本文详细探讨了系统架构师在处理本地事务隔离级别及并发控制方面的重要知识点。首先,介绍了并发操作引发的数据不一致性问题,包括丢失修改、不可重复读、读脏数据和幻读。接着,重点讲解了常见的并发控制...

    包含事务相关的内容.rar_java编程

    在Java编程领域,事务管理是核心概念之一,特别是在开发...以上内容涵盖了Java编程中事务管理的主要方面,包括基本概念、事务处理方式、Spring框架的应用以及分布式事务等,对于理解和解决面试中的相关问题至关重要。

    深入理解spring的事务管理机制

    3. **注入事务配置**:在代理对象中注入事务相关的配置,如事务的传播行为、隔离级别等。 4. **事务处理**:在调用被代理的方法时,Spring会自动处理事务的开启、提交或回滚。 #### 二、Spring事务的传播属性 ...

    msyql锁、事务隔离级别各种场景验证测试.rar

    这意味着所有相关的数据规 则都必须应用于事务的修改,以保持数据的完整性。(可以理解为抽象出来的内容同现实内容的相互映射关系要一致)。 C是目的,其他三个AID属性是手段。 隔离性(Isolation) :数据库系统提供...

    Oracle事务与锁定

    锁定类型包括共享锁(读锁)、排他锁(写锁)和其他多种类型的行级、表级和模式级别的锁。当一个事务持有锁时,其他事务必须等待锁被释放才能进行相应的操作。这样既保证了数据一致性,也实现了并发访问的安全性。 ...

    Spring事务管理失效原因汇总

    标题“Spring事务管理失效原因汇总”指出了本文的核心内容是分析在使用Spring框架进行事务管理时可能遇到的问题及其原因。描述部分进一步说明了事务失效的后果往往不明显,容易在测试环节被忽略,但在生产环境中出现...

    Spring aop、jdbc和事务tx练习

    在"Spring_Day10"这个压缩包中,你可能找到了相关的练习项目,这些项目可能包含以下内容: - 一个Spring配置文件,定义了bean、AOP切面、数据源和事务管理器。 - 使用了@Autowired注解自动装配Bean的Java类,展示了...

    SAP事务代码大全(珍藏版)

    - **CA-CL-CHR特性**:与分类系统相关的具体属性或特征,如分类标准、分类级别等。 - **CA-CADCAD集成**:实现SAP系统与其他CAD软件之间的数据交换。 - **CA-BFA-ALE ALE集成技术**:高级物流执行(Advanced ...

    ssh上传文件,测试事务

    5. **事务管理注解**:在需要进行事务管理的业务方法上添加@Transactional注解,指定事务的传播行为、隔离级别等属性。 6. **事务测试**:编写测试用例,模拟各种异常情况,如网络中断、数据库错误等,检查事务是否...

    配置事务通知

    5. 理解源码级别的事务管理实现,以便更深入地调试和优化事务行为。 6. 掌握字符串编码转换的方法,这对于处理日志信息和数据交互至关重要。 在实际项目中,正确配置和使用事务通知能有效防止数据不一致,提高系统...

    家庭事务管理

    C语言是一种强大的、低级别的编程语言,它被广泛用于系统编程和开发各种应用程序。它的效率高、灵活性强,是编写管理程序的理想选择。在这个家庭事务管理系统中,C语言将被用来创建一个用户友好的界面,以及一套高效...

    律师事务所保密制度.pdf

    通过定期的培训和考核,确保每位员工都能充分理解保密制度的内容和意义,从而在日常工作中自觉地保护事务所的敏感信息。 总而言之,《律师事务所保密制度》是事务所运营中的必要保障,它不仅保护了事务所的商业秘密...

    pring事务共9页.pdf.zip

    通常,一个关于Spring事务的压缩包内应该包含相关的PDF文档,如“Spring事务管理.pdf”等,而不是与赚钱项目相关的内容。 综合以上信息,我们可以推测这个压缩包内的文档将涵盖以下几个核心知识点: 1. **Spring...

    数据库的事务处理方法精讲

    以上就是关于“数据库的事务处理方法精讲”的主要内容。了解并熟练掌握这些知识点,对于开发高效、可靠的数据库应用程序至关重要。在实际工作中,应根据项目需求和性能要求灵活选择和应用不同的事务处理策略。

    一个简单的方法来实现数据库的事务

    从给定的信息来看,虽然部分内容似乎是乱码,但根据标题、描述及标签,我们可以提炼出关于如何在数据库中实现简单事务处理的相关知识点。 ### 一个简单的方法来实现数据库的事务 #### 一、事务的基本概念 事务...

    spring3,hibernate4 配置声明式事务管理(annotation方式)

    在Java开发中,Spring框架和Hibernate ORM工具是两个非常重要的组件。Spring提供了强大的依赖注入(DI...在实际开发中,可以根据项目需求调整事务的传播属性、隔离级别、超时限制等高级特性,以实现更精细的事务管理。

    Spring_tx事务

    在Spring_day3_tx这个压缩包中,可能包含了一些关于Spring事务管理的示例代码或者教程资料,包括如何配置事务管理器、如何使用`@Transactional`注解、如何处理事务异常等内容。通过学习这些资料,你可以更深入地理解...

Global site tag (gtag.js) - Google Analytics