事务是并发控制的基本单元。所谓事务一个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 出现错误 结果还是不变的。