MySQL 的事务级别(Transaction Isolation Levels)定义了事务可能受其他并发事务影响的程度。这些级别帮助数据库管理系统(DBMS)处理多个事务同时运行时可能发生的并发问题,如脏读(Dirty Reads)、不可重复读(Non-repeatable Reads)和幻读(Phantom Reads)。
MySQL 支持以下四种标准的事务隔离级别,从低到高依次为:
- READ UNCOMMITTED(读未提交)
- 这是最低的隔离级别。在此级别下,一个事务可以读取到另一个事务未提交的数据。这可能导致脏读、不可重复读和幻读。
- 允许读取尚未提交的数据变更,可能会导致数据的不一致。
- READ COMMITTED(读已提交)
- 在这个级别,一个事务只能看到已经提交事务所做的数据变更。这意味着一个事务从开始到提交前所做的任何数据变更对其他事务都是不可见的。这可以防止脏读,但不可重复读和幻读仍可能发生。
- MySQL 的默认事务隔离级别是 REPEATABLE READ,但如果你将事务隔离级别设置为 READ COMMITTED,MySQL 将只保证不会脏读,但可能会有不可重复读和幻读。
- REPEATABLE READ(可重复读)
- 这是 MySQL 的默认事务隔离级别。在此级别下,保证在同一个事务中多次读取同样记录的结果是一致的。但是,理论上还是有可能发生幻读(即一个事务重新读取一个范围的记录时,看到了另一个事务插入的属于同一范围的新记录)。
- MySQL 的 InnoDB 存储引擎通过多版本并发控制(MVCC)和 Next-Key Locks 解决了幻读问题,使得在 REPEATABLE READ 级别下也能避免幻读。
- SERIALIZABLE(可串行化)
- 这是最高的隔离级别。它通过强制事务串行执行,来避免脏读、不可重复读和幻读。事务只能一个接一个地执行,这会导致性能下降。
- 在这个级别下,事务完全隔离,但可能导致大量并发事务时性能下降。
设置事务隔离级别可以使用 SQL 语句:
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE;
注意,这些设置是针对当前会话的,如果需要全局设置,可以在 MySQL 的配置文件(如 my.cnf 或 my.ini)中设置,但通常不推荐这样做,因为它会影响所有连接和应用程序的性能。
355

被折叠的 条评论
为什么被折叠?



