java事物的理解

来源:互联网 发布:python如何连接小票机 编辑:程序博客网 时间:2024/05/22 03:02

事务是并发控制的基本单元。所谓事务一个sql语句操作序列,这些操作要么都执行,要么都不执行,他是一个不可分割的工作单元。

例如:银行转账工作,从一个帐号扣款并使另一个帐号增款,这个两个操作,要么都执行,要么都不执行。

数据库的事务必须具备ACID特性,ACID是指 Atomic(原子性)、Consistensy(一致性)、Isolation(隔离型)和Durability(持久性)的英文缩写。

 

1、原子性(Atomicity)

一个事务中所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中如果发生错误,会被回滚到事务开始前的状态,就像这个事务从来没有执行一样。

2、一致性(Consistency)

一个事务在执行之前和执行之后数据库都必须处于一致性状态。

如果事务成功的完成,那么数据库的所有变化将生效。

如果事务执行出现错误,那么数据库的所有变化将会被回滚(撤销),返回到原始状态。

 

举例1: a、b 转账 100

a - 100

b + 100

 

结果: a + b = 2000

 

举例2:公司部门 和 员工信息,前提是每个员工都有部门

需求:解散一个部门,

分析:删除一个部门 --》 导致员工找不到对应的部门  --》 造成员工的部门信息不一致

解决:应该先删除部门的员工,再删除部门, 保证数据的一致性

 

3、隔离性(Isolation)

多个用户并发的访问数据库时,一个用户的事务不能被其他用户的事务干扰,多个并发的事务之间要相互隔离。

 

多个事务事件是相互独立的,多个事务事件不能相互干扰。

 

a -b ----- 事务A

c -d ----- 事务B

 

如果A失败了,不能影响B。

4、持久性:

指一个事务一旦被提交,它对数据库的改变将是永久性的,接下来即使数据库发生故障也不会对数据产生影响。

举例:a、b转账

a-100

b+100

提交

结果: a 900 b 1100

 

开启事务

a - 100 出现错误 结果还是不变的。

0 0