|
31 | 31 | </div>
|
32 | 32 |
|
33 | 33 | 1. **原子性:** 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用;
|
34 |
| -2. **一致性:** 执行事务前后,数据保持一致; |
35 |
| -3. **隔离性:** 并发访问数据库时,一个用户的事物不被其他事物所干扰,各并发事务之间数据库是独立的; |
| 34 | +2. **一致性:** 执行事务前后,数据保持一致,多个事务对同一个数据读取的结果是相同的; |
| 35 | +3. **隔离性:** 并发访问数据库时,一个用户的事务不被其他事务所干扰,各并发事务之间数据库是独立的; |
36 | 36 | 4. **持久性:** 一个事务被提交之后。它对数据库中数据的改变是持久的,即使数据库发生故障也不应该对其有任何影响。
|
37 | 37 |
|
38 | 38 | ### 并发事务带来的问题
|
39 | 39 |
|
40 |
| -在典型的应用程序中,多个事务并发运行,经常会操作相同的数据来完成各自的任务(多个用户对统一数据进行操作)。并发虽然是必须的,但可能会导致一下的问题。 |
| 40 | +在典型的应用程序中,多个事务并发运行,经常会操作相同的数据来完成各自的任务(多个用户对统一数据进行操作)。并发虽然是必须的,但可能会导致以下的问题。 |
41 | 41 |
|
42 | 42 | - **脏读(Dirty read):** 当一个事务正在访问数据并且对数据进行了修改,而这种修改还没有提交到数据库中,这时另外一个事务也访问了这个数据,然后使用了这个数据。因为这个数据是还没有提交的数据,那么另外一个事务读到的这个数据是“脏数据”,依据“脏数据”所做的操作可能是不正确的。
|
43 | 43 | - **丢失修改(Lost to modify):** 指在一个事务读取一个数据时,另外一个事务也访问了该数据,那么在第一个事务中修改了这个数据后,第二个事务也修改了这个数据。这样第一个事务内的修改结果就被丢失,因此称为丢失修改。 例如:事务1读取某表中的数据A=20,事务2也读取A=20,事务1修改A=A-1,事务2也修改A=A-1,最终结果A=19,事务1的修改被丢失。
|
|
58 | 58 |
|
59 | 59 | - **READ-UNCOMMITTED(读取未提交):** 最低的隔离级别,允许读取尚未提交的数据变更,**可能会导致脏读、幻读或不可重复读**
|
60 | 60 | - **READ-COMMITTED(读取已提交):** 允许读取并发事务已经提交的数据,**可以阻止脏读,但是幻读或不可重复读仍有可能发生**
|
61 |
| -- **REPEATABLE-READ(可重读):** 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,**可以阻止脏读和不可重复读,但幻读仍有可能发生。** |
| 61 | +- **REPEATABLE-READ(可重复读):** 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,**可以阻止脏读和不可重复读,但幻读仍有可能发生。** |
62 | 62 | - **SERIALIZABLE(可串行化):** 最高的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,**该级别可以防止脏读、不可重复读以及幻读**。
|
63 | 63 |
|
| 64 | +---- |
| 65 | + |
| 66 | +| 隔离级别 | 脏读 | 不可重复读 | 幻影读 | |
| 67 | +| :---: | :---: | :---:| :---: | |
| 68 | +| READ-UNCOMMITTED | √ | √ | √ | |
| 69 | +| READ-COMMITTED | × | √ | √ | |
| 70 | +| REPEATABLE-READ | × | × | √ | |
| 71 | +| SERIALIZABLE | × | × | × | |
| 72 | + |
64 | 73 | MySQL InnoDB 存储引擎的默认支持的隔离级别是 **REPEATABLE-READ(可重读)**。我们可以通过`SELECT @@tx_isolation;`命令来查看
|
65 | 74 |
|
66 | 75 | ```sql
|
@@ -136,3 +145,5 @@ SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL [READ UNCOMMITTED|READ COMMITTE
|
136 | 145 |
|
137 | 146 | - 《MySQL技术内幕:InnoDB存储引擎》
|
138 | 147 | - <https://dev.mysql.com/doc/refman/5.7/en/>
|
| 148 | +- [Mysql 锁:灵魂七拷问](https://tech.youzan.com/seven-questions-about-the-lock-of-mysql/) |
| 149 | +- [Innodb 中的事务隔离级别和锁的关系](https://tech.meituan.com/2014/08/20/innodb-lock.html) |
0 commit comments