mysql四大特性与四种隔离级别

四大特性

1:原子性。事务是一个不可分割的整体,事务开始的操作,要么全部执行,要么全部不执行。

2:隔离性。同一时间,只允许一个事务请求同一组数据。不同的事务彼此之间没有干扰。

3:一致性。事务开始前和结束后,数据库的完整性约束没有被破坏 。

4:稳定性。事务完成后,事务对数据库的所有更新将被保存到数据库,不能回滚。

隔离性的四种级别

1: read uncommitted。事务A对数据进行修改,但未提交。此时开启事务B,在事务B中能读到事务A中对数据库进行的未提交数据的修改。(这种方式也称为脏读

2 :read committed。事务A对数据进行修改,但还未提交。此时开启事务B,在事务B中不能读到事务A中对数据库的修改。在事务B还没有关闭时,此时事务A提交对数据库的修改。这时候,我们在事务B中,可以查到事务A中对数据库的修改。这时存在一个问题,我们在同一个事务中,对数据库查询两次,但两次的结果是不一样的。(这种方式称为不可重复读。)

3 :repetition read。事务A对数据进行修改,但未提交,此时开启事务B,在事务B中不能读到事务A对数据库的修改。在事务A提交对数据库修改时,此时在事务B中,仍不能读到事务A对数据库的修改。(这种方式称为可重复读)但此时有一个弊端,比如我们在事务A中对数据库增加一条数据,id 为 n ,这时候我们在事务B中查询数据,此时查不到id为n的数据。但当我们在事务B中增加id为n的数据时,系统会提示id为n的数据已经存在,我们添加失败。但此时此刻,我们在事务B中仍不能查询到id为n的数据。这种方式存在一个幻读的概念。举个例子,(系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后关闭事务发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。)

4 :serializable。在开启事务A时,会产生锁表,此时别的事务会等待,等事务A结束时才会开启。

猜你喜欢

转载自blog.csdn.net/qq_41982304/article/details/81503238