一.事务的四大特性:
原子性: 事务中的所有操作都是不可分割的原子操作,事务的执行,要么全部成功,要么全部失败。
一致性:事务执行后,数据库状态与其它业务规则保持一致。如转账业务,无论事务执行成功与否,参与转账的两个账号余额之和应该是不变的。
隔离性:在并发操作中,多个事务需要隔离开分别执行。
持久性:在事务执行完毕之后,数据库中的数据无论在什么情况下都不会发生改变。
注意:若没有隔离性则会引发一系列的问题(脏读,不可重复读,虚读)
二.事务的并发读问题:
脏读:一个事务读到另外一个事务的未提交数据。
不可重复读:两次读取的结果不一致(由于在事务进行第一次读取后,另外一个事务对表中的数据进行修改)。
虚读:读到另一事务已提交数据(对表中的两次查询结果不一致,由于在一个事务第一次读取后,另外一个事务向表中增加记录)。
三.隔离级别:
1.SERIALIZABLE(串行化)三种读问题都能处理
2.REPEATABLE READ(可重复读)脏读、不可重复读,不能处理幻读(MySQL默认隔离级别)
3.READ COMMITTED(读已提交数据)只能处理脏读,不能处理不可重复读和幻读。(Oracle默认隔离级别)
4.READ UNCOMMITTED(读未提交数据)啥也不处理!
事务
最新推荐文章于 2023-06-05 15:20:09 发布