一.事务的概念
1.事务是什么
事务是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合。
2.事务的四种特性(ACID)
a.原子性
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
b.一致性
事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。
c.隔离性
一个事务的执行不能被其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。两个事务之间是有隔离级别,隔离级别的不同会导致出现不同的问题。此时产生三种读: 脏读 幻读 不可重复读。
d.持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
3.事务的隔离级别
级别越高,效率越低;mysql的默认隔离级别是可重复读
4.事务的并发问题
ps:不可重复读和幻读是很容易混淆的,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需要锁住满足条件的行,解决幻读需要锁表