事务及其特性ACID

一、事务的定义

??事务是一组单元化的操作,这组操作可以保证要么全部成功,要么全部失败(只要有一个失败的操作,就会把其他已经成功的操作回滚)。

??一般所说的数据库事务,它是访问并可能更新数据库中各种数据项的一个程序执行单元,由一个有限的数据库操作序列构成。当事务被提交给了DBMS(数据库管理系统),则DBMS(数据库管理系统)需要确保该事务中的所有操作都成功完成且其结果被永久保存在数据库中,如果事务中有的操作没有成功完成,则事务中的所有操作都需要被回滚,回到事务执行前的状态;同时,该事务对数据库或者其他事务的执行无影响,所有的事务都好像在独立的运行。

二、事务的特性ACID

??1、原子性(A)

??所谓的原子性就是说,在整个事务中的所有操作,要么全部完成,要么全部不做,没有中间状态。对于事务在执行中发生错误,所有的操作都会被回滚,整个事务就像从没被执行过一样。

??2、一致性(C)

??事务的执行必须保证系统的一致性,就拿转账为例,A有300元,B有100元,如果在一个事务里A成功转给B50元,那么不管并发多少,不管发生什么,只要事务执行成功了,那么最后A账户一定是250元,B账户一定是150元。

??3、隔离性(I)

??所谓的隔离性就是说,事务与事务之间不会互相影响,一个事务的中间状态不会被其他事务感知。 即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。事务有多种隔离级别。

??4、持久性(D)

??所谓的持久性,就是说一旦事务完成了,那么事务对数据所做的变更就完全保存在了数据库中,即使发生停电,系统宕机也是如此。

三、事务的实现方式

??事务的原子性、一致性和持久性,数据库管理系统采用日志来保证。日志记录了事务对数据库所做的操作,如果某个事务在执行过程中发生错误,就可以根据日志,撤销事务对数据库已做的操作,使数据库退回到执行事务前的初始状态。

??事务的隔离性,数据库管理系统采用锁机制来实现。当多个事务同时更新数据库中相同的数据时,只允许持有锁的事务能更新该数据,其他事务必须等待,直到前一个事务释放了锁,其他事务才有机会更新该数据。

四、特别说明

??特别说明:原子性并不能保证一致性,所以有了原子性为什么还要一致性

??对于单个事务,原子性就能保证一致性,但是对于多个并发执行的事务,即使每个事务都是原子执行的,但它们同时执行的话,最终效果可能会不一致。举例如下:

有A、B、C三个账户各有200元钱,其中事务1是A向B转账100,则执行语句如下:

update A set amount=amount-100 where id = 1;
update B set amount=amount+100 where id = 1;

事务2是C向B转账100,则执行语句如下:

update C set amount=amount-100 where id = 1;
update B set amount=amount+100 where id = 1;

??如果事务1和事务2同时执行的一致性结果应该是B账户里面有300元钱,但是在并发事务下,事务1和事务2同时执行时,两个事务读到的账户B的当前金额都可能是100(脏读),不管两个事务谁先执行完成,最终的执行结果都是B账户金额为200。这就是事务特性除了原子性外还需要一致性。
??因此,要达到事务的一致性,除了要保证单个事务的原子性之外,还要保证事务之间的隔离性

原文地址:https://www.cnblogs.com/xtiger/p/10513908.html

时间: 2024-11-05 04:52:04

事务及其特性ACID的相关文章

数据库 事务的特性ACID

事务(Transaction)是并发控制的基本单位. 所谓事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位.例如,银行转帐工作:从一个帐号扣款并使另一个帐号增款,这两个操作要么都执行,要么都不执行. 数据库事务必须具备ACID特性,ACID是Atomic(原子性).Consistency(一致性).Isolation(隔离性)和Durability(持久性)的英文缩写. 原子性:指整个数据库事务是不可分割的工作单位.只有使据库中所有的操作执行成功,才算整个事务

python事务四大特性ACID

1.原子性 整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部分操作 2.一致性 一致性就是在没有提交事务前,不管理对数据操作多少次,真实的数据都不会改动,只有提交了事务才会数据更改 3.隔离性 隔离性就是在没有完成本次事务前,不允许其他用户对数据的操作 4.持久性 一旦事务提交了,就永久写到数据库中了 原文地址:https://www.cnblogs.com/zrf-516/p/9021016.html

事务的特性和隔离级别

1.事务的特性ACID 1)原子性(Atomicity)原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生. 2)一致性(Consistency)一个事务中,事务前后数据的完整性必须保持一致. 3)隔离性(Isolation)多个事务,事务的隔离性是指多个用户并发访问数据库时, 一个用户的 事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离. 4)持久性(Durability)持久性是指一个事务一旦被提交,它对数据库中数据的改变 就是永久性的,接下来即使数据

JAVAWEB开发之事务详解(mysql与JDBC下使用方法、事务的特性、锁机制)和连接池的详细使用(dbcp以d3p0)

事务简介 事务的概念:事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部不成功 在开发中,有事务的存在,可以保证数据的完整性. 注意:数据库默认事务是自动提交的,也就是发一条SQL 就执行一条.如果想多条SQL语句放在一个事务中执行,需要添加事务有关的语句. 如何开启事务? 事务的操作方式: 创建表: create table account( id int primary key auto_increment, name varchar(20), money double

什么是事务、事务特性、事务隔离级别、spring事务传播特性

1.什么是事务: 事务是程序中一系列严密的操作,所有操作执行必须成功完成,否则在每个操作所做的更改将会被撤销,这也是事务的原子性(要么成功,要么失败). 2.事务特性: 事务特性分为四个:原子性(Atomicity).一致性(Consistency).隔离性(Isolation).持续性(Durability)简称ACID. 原子性(Atomicity):事务是数据库逻辑工作单元,事务中包含的操作要么都执行成功,要么都执行失败. 一致性(Consistency):事务执行的结果必须是使数据库数据

MySQL事务内幕与ACID

MySQL的事务实现严格遵循ACID特性,即原子性(atomicity),一致性(consistency),隔离性(isolation),持久性(durability).为了避免一上来就陷入对ACID的概念理解,我们直接先谈MySQL事务实现机制. MySQL提供了两种事务型的存储引擎:InnoDB和NDB Cluster.另外还有一些第三方存储引擎也支持事务,比较知名的包括XtraDB和PBXT.下面以InnoDB来说明. MySQL会最大程度的使用缓存机制来提高数据库的访问效率,但是万一数据

事务、事务特性、事务隔离级别、spring事务传播特性

1.什么是事务: 事务是程序中一系列严密的操作,所有操作执行必须成功完成,否则在每个操作所做的更改将会被撤销,这也是事务的原子性(要么成功,要么失败). 2.事务特性: 事务特性分为四个:原子性(Atomicity).一致性(Consistency).隔离性(Isolation).持续性(Durability)简称ACID. 原子性(Atomicity):事务是数据库逻辑工作单元,事务中包含的操作要么都执行成功,要么都执行失败. 一致性(Consistency):事务执行的结果必须是使数据库数据

事务的特性

事务作为单个逻辑工作单元执行一系列的操作,一个逻辑工作单元必须具有四个属性:原子性,一致性,隔离性,持久性,只有同时满足这四个特性,才能成为一个事务. 一,事务的四个属性 原子性:事务是原子工作单元,对于数据修改,要么全部执行,要么全部不执行. 一致性:事务在完成时,必须保证数据对象的所有状态都保持一致,事务结束时,所有的内部数据结构(索引,索引视图等)都必须是正确的. 隔离性:由并发事务所做的修改必须与其他任何并发事务所做的修改隔离. 持久性:事务完成之后,对数据的修改是永久性的. 二,事务的

数据库事务的四大特性ACID

本篇讲诉数据库中事务的四大特性(ACID),并且将会详细地说明事务的隔离级别. 如果一个数据库声称支持事务的操作,那么该数据库必须要具备以下四个特性: ⑴ 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,所以事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响.为了实现原子性,需要通过日志:将所有对数据的更新操作都写入日志,如果一个事务中的一部分操作已经成功,但以后的操作,由于断电/系统崩溃/其它的软硬件错误而无法继续,则通过