数据库事务特性及事务隔离级别

一、数据库事务基本知识

1.数据库事务:要么全部成功,要么全部失败。

2.数据库事务特性:原子性、一致性、隔离性、持久性

原子性:组成一个事务的多个数据库操作是一个不可分割的原子单元,只有所有操作都成功,整个事务才会提交。任何一个操作失败,已经执行的任何操作都必须撤销,让数据库返回初始状态。

一致性:事务操作成功后,数据库所处的状态和它的业务规则是一致的。即数据不会被破坏。如A转账100元给B,不管操作是否成功,A和B的账户总额是不变的。

隔离性:在并发数据操作时,不同的事务拥有各自的数据空间,它们的操作不会对彼此产生干扰

持久性:一旦事务提交成功,事务中的所有操作都必须持久化到数据库中。

二、数据并发问题

数据库中的数据可能同时被多个事务访问,如果没有采取必要的隔离措施,就会导致各种并发问题,破坏数据的完整性。

1.脏读:A事务读取B事务尚未提交的更改数据,并在这个数据的基础上进行操作。如果恰巧B事务回滚,那么A事务读取到的数据是根本不被承认的。

2.不可重复读:A事务读取了B事务已经提交的更改数据。

3.幻读:A事务读取了B事务提交的新增数据。

三、事务隔离级别

READ_UNCOMMITED、READ_COMMITTED、REPEATABLE_READ、SERIALIZABLE

猜你喜欢

转载自www.cnblogs.com/expiator/p/9626123.html