`
myharmony
  • 浏览: 108279 次
  • 性别: Icon_minigender_1
  • 来自: 中山市
社区版块
存档分类
最新评论

事务的:原子性、一致性、分离性、持久性

阅读更多
原子性、一致性、分离性、持久性
(1) 原子性
 事务的原子性指的是,事务中包含的程序作为数据库的逻辑工作单位,它所做的对数据修改操作要么全部执行,要么完全不执行。这种特性称为原子性。
 事务的原子性要求,如果把一个事务可看作是一个程序,它要么完整的被执行,要么完全不执行。就是说事务的操纵序列或者完全应用到数据库或者完全不影响数据库。这种特性称为原子性。
  假如用户在一个事务内完成了对数据库的更新,这时所有的更新对外部世界必须是可见的,或者完全没有更新。前者称事务已提交,后者称事务撤消(或流产)。DBMS必须确保由成功提交的事务完成的所有操纵在数据库内有完全的反映,而失败的事务对数据库完全没有影响。

(2) 一致性
    事务的一致性指的是在一个事务执行之前和执行之后数据库都必须处于一致性状态。这种特性称为事务的一致性。假如数据库的状态满足所有的完整性约束,就说该数据库是一致的。
一致性处理数据库中对所有语义约束的保护。假如数据库的状态满足所有的完整性约束,就说该数据库是一致的。例如,当数据库处于一致性状态S1时,对数据库执行一个事务,在事务执行期间假定数据库的状态是不一致的,当事务执行结束时,数据库处在一致性状态S2。

(3) 分离性
分离性指并发的事务是相互隔离的。即一个事务内部的操作及正在操作的数据必须封锁起来,不被其它企图进行修改的事务看到。
  分离性是DBMS针对并发事务间的冲突提供的安全保证。DBMS可以通过加锁在并发执行的事务间提供不同级别的分离。假如并发交叉执行的事务没有任何控制,操纵相同的共享对象的多个并发事务的执行可能引起异常情况。
DBMS可以在并发执行的事务间提供不同级别的分离。分离的级别和并发事务的吞吐量之间存在反比关系。较多事务的可分离性可能会带来较高的冲突和较多的事务流产。流产的事务要消耗资源,这些资源必须要重新被访问。因此,确保高分离级别的DBMS需要更多的开销。

(4)持久性
持久性意味着当系统或介质发生故障时,确保已提交事务的更新不能丢失。即一旦一个事务提交,DBMS保证它对数据库中数据的改变应该是永久性的,耐得住任何系统故障。持久性通过数据库备份和恢复来保证。
持久性意味着当系统或介质发生故障时,确保已提交事务的更新不能丢失。即对已提交事务的更新能恢复。一旦一个事务被提交,DBMS必须保证提供适当的冗余,使其耐得住系统的故障。所以,持久性主要在于DBMS的恢复性能。
分享到:
评论

相关推荐

    多库多事务降低数据不一致概率

    在实际的业务场景中,为了确保数据的正确性和完整性,通常会利用事务处理机制来保证数据库操作的ACID特性(原子性、一致性、隔离性、持久性)。以一个简单的订单创建过程为例:当用户下单时,系统需要更新用户的余额...

    分布式事务若依框架文档

    - **一致性(Consistency)**:事务处理前后,数据必须保持一致状态。这意味着事务应该保证数据从一种一致状态转移到另一种一致状态,而不会导致数据的完整性约束被破坏。 - **隔离性(Isolation)**:当多个事务...

    省级业务运营支撑系统业务技术规范-数据一致性管理机制分册

    1. 事务处理:基于ACID(原子性、一致性、隔离性、持久性)原则,确保每个操作(事务)要么全部完成,要么全部不完成,避免部分执行导致数据不一致。 2. 分布式事务:在分布式环境中,通过两阶段提交(2PC)或三阶段...

    网络游戏-用于网络服务配置的事务完整性.zip

    - 一致性(Consistency):事务完成后,系统状态必须保持一致,不会出现不合法的数据状态。 - 隔离性(Isolation):并发执行的事务之间相互隔离,不会互相干扰,看到的数据是一致的。 - 持久性(Durability):...

    Java事务设计模式_java_事务设计模式_

    事务是数据库操作的基本单元,它保证了一组操作要么全部成功,要么全部失败,遵循ACID(原子性、一致性、隔离性和持久性)原则。在Java中,事务管理是通过JDBC API或者Spring框架的Transaction API来实现的。 1. **...

    一种多核友好的持久性内存键值系统.docx

    1. 易失性锁管理机制:为了避免锁资源导致的额外持久性内存写带宽消耗,MPKV将写锁资源从索引中分离出来,存储在DRAM中。这种设计减少了锁操作对持久性内存的依赖,降低了CPU缓存和TLB的缺失,从而提高了并发效率。 ...

    JEE事务课程资料

    分布式事务遵守ACID原则,即原子性、一致性、隔离性和持久性。在分布式事务中,稳定性尤为重要,因为涉及到的数据可能分布在不同的物理位置,若数据库崩溃,需要一个有效的恢复机制。 四、声明性事务 声明性事务是...

    Atomikos实现分布式事务

    每个数据库操作都应该在事务管理器的控制下进行,确保它们都遵循ACID(原子性、一致性、隔离性和持久性)原则。 6. **提交或回滚事务**:根据业务逻辑的结果,决定是提交还是回滚整个事务。如果所有操作都成功,...

    spring事务分析

    - **ACID特性**:事务具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。原子性保证事务中的操作不可分割,一致性确保事务完成后系统处于合法状态,隔离性防止事务间的...

    深入解析Java的Spring框架中的混合事务与bean的区分

    事务有四个基本属性,通常被称为ACID(原子性、一致性、隔离性和持久性)。Spring提供了两种事务管理方式:声明式事务管理和编程式事务管理。声明式事务基于AOP(面向切面编程),通过在方法上添加注解如`@...

    Spring 事务开发代码文件

    - 一致性(Consistency):事务完成后,系统状态必须保持一致。 - 隔离性(Isolation):并发事务之间应互相隔离,防止相互干扰。 - 持久性(Durability):一旦事务提交,其结果就永久保存下来,即使系统崩溃也...

    spring与mybatis整合实现事务配置

    1. **事务的ACID特性**:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)。在Spring中,这些特性都得到了很好的支持。 2. **事务的隔离级别**:读未提交(READ ...

    分布式事务中间件JDTX介绍.pptx

    JDTX致力于提供一种透明化的分布式事务处理机制,它不仅支持ACID(原子性、一致性、隔离性和持久性)的强一致事务,而且具备高性能、高可用性的特点。在设计上,JDTX避免了传统两阶段提交(2PC)的局限性,旨在提高...

    10-Spring-事务管理1

    事务是一系列数据库操作的逻辑单元,它具有四个关键属性,即ACID(原子性、一致性、隔离性和持久性)。原子性确保事务中的所有操作要么全部执行,要么全部不执行;一致性保证事务结束后,系统处于一致状态,符合...

    AOP及事务代码示例

    事务具有ACID(原子性、一致性、隔离性和持久性)属性,保证了即使在系统异常情况下也能正确处理数据。在编程中,事务管理通常涉及以下方面: 1. **原子性(Atomicity)**:事务中的所有操作要么全部成功,要么全部...

    一次长事务导致数据库锁等待超时问题跟踪

    2. 事务管理最佳实践:遵循ACID(原子性、一致性、隔离性、持久性)原则,及时提交或回滚事务。 3. 定期监控与调优:定期进行数据库性能监控和调优,预防潜在的锁等待问题。 总之,一次长事务导致数据库锁等待超时...

    spring事务(附件pdf)

    事务有四个基本特性,即ACID原则:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。在Spring中,事务管理可以帮助我们更好地实现这些原则。 Spring事务管理主要有两种...

    spring事务

    - **持久性(Durability)**:事务一旦提交,其结果就是永久的。 5. **并发事务问题**: - **脏读**:一个事务读取了另一个未提交事务的数据。 - **不可重复读**:同一个事务内多次读取同一数据,结果不一致,...

    在SQL中操作Redis或者Redis集群,达到Redis与MySQL的数据一致性.zip

    MySQL是ACID(原子性、一致性、隔离性、持久性)事务的典范,适用于需要强一致性的场景。其InnoDB引擎支持行级锁定,保证了并发下的数据正确性。但相比于Redis,MySQL的读写速度较慢,特别是在高并发下。 要实现...

    26.第二十六阶段、微服务架构的分布式事务解决方案视频全集

    传统的事务ACID(原子性、一致性、隔离性、持久性)属性在分布式环境下变得更加复杂。 #### 传统事务的局限性 - **原子性**:在分布式环境中,由于网络延迟等因素,很难保证所有参与者的操作都能同时成功或失败。 ...

Global site tag (gtag.js) - Google Analytics