事务是由一组SQL语句组成的逻辑处理单元
如果事务并发操作会导致以下问题:
更新丢失(Lost Update)或脏写
事务A和事务B都要对同一条记录修改,如果事务A先提交,事务B再提交,那么事务A提交的数据被覆盖,就是脏写
脏读(Dirty Reads)
事务A对一条记录进行修改,但还未提交,此时事务B读到这条被A修改的数据,如果此时事务A回滚,那么这条数据就是脏数据
不可重复读(Non-Repeatable Reads)
事务内读取了一条数据,一段时间后(期间另一个事务修改了这条数据并提交),再次读取这条数据,但这条数据发生了改变
幻读(Phantom Reads)
事务两次读取数据结果集数量不一致。事务A读取到了事务B提交的新增数据
“脏读”、“不可重复读”和“幻读”,其实都是数据库读一致性问题,必须由数据库提供一定的事务隔离机制来解决。
隔离级别 | 脏读 | 不可重复读 | 幻读 |
---|---|---|---|
读未提交(Read uncommitted) | 可能 | 可能 | 可能 |
读已提交(Read committed) | 不可能 | 可能 | 可能 |
可重复读(Repeatable read) | 不可能 | 不可能 | 可能 |
可串行化读(Serializable) | 不可能 | 不可能 | 不可能 |
常看当前数据库的事务隔离级别:
select @@transaction_isolation;
show variables like ‘tx_isolation’;
mysql默认的隔离级别是可重复读(Repeatable read)